/* ===== DARK MODE (default) ===== */
:root {
  --bg-primary:      #0A0F1C;
  --bg-secondary:    #111827;
  --bg-card:         rgba(10,15,28,0.7);
  --green:           #00CC00;
  --green-hover:     #00DD00;
  --indigo:          #4338CA;
  --text-primary:    #FFFFFF;
  --text-secondary:  #D1D5DB;
  --text-muted:      #9CA3AF;
  /* legacy aliases used in service pages */
  --text-gray:       #9CA3AF;
  --text-gray-light: #D1D5DB;
  --text-gray-dark:  #6B7280;
  --border:          rgba(255,255,255,0.1);
  --glass-bg:        rgba(10,15,28,0.7);
  --shadow:          rgba(0,0,0,0.3);
  --scrollbar-track: #0A0F1C;
  --scrollbar-thumb: #1F2937;
  --scrollbar-hover: #374151;
  --font-heading: 'Outfit', sans-serif;
  --font-body:    'Manrope', sans-serif;
}

/* ===== LIGHT MODE ===== */
body.light-mode,
html.light-mode body {
  --bg-primary:      #F8FAFC;
  --bg-secondary:    #F1F5F9;
  --bg-card:         rgba(255,255,255,0.9);
  --text-primary:    #0F172A;
  --text-secondary:  #334155;
  --text-muted:      #64748B;
  /* legacy aliases */
  --text-gray:       #64748B;
  --text-gray-light: #334155;
  --text-gray-dark:  #475569;
  --border:          rgba(0,0,0,0.1);
  --glass-bg:        rgba(255,255,255,0.85);
  --shadow:          rgba(0,0,0,0.08);
  --scrollbar-track: #F1F5F9;
  --scrollbar-thumb: #CBD5E1;
  --scrollbar-hover: #94A3B8;
}

/* ===== SKIP LINK ===== */
.skip-link {
  position: absolute; top: -100%; left: 1rem;
  background: var(--green); color: #000; padding: .5rem 1rem;
  border-radius: 0 0 .5rem .5rem; font-weight: 700; font-size: .875rem;
  z-index: 9999; transition: top .2s;
}
.skip-link:focus { top: 0; }

/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  transition: background .3s ease, color .3s ease;
}
h1,h2,h3,h4,h5,h6 { font-family: var(--font-heading); color: var(--text-primary); }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--scrollbar-track); }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 5px; }
::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-hover); }
::selection { background: rgba(0,204,0,0.3); color: var(--text-primary); }

/* ===== UTILITIES ===== */
.container { max-width: 1280px; margin: 0 auto; padding: 0 3rem; }
@media(max-width:768px){ .container { padding: 0 1.5rem; } }

/* Visually hidden but accessible to screen readers */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.gradient-text-accent {
  background: linear-gradient(135deg, #00CC00 0%, #0033CC 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.glass {
  backdrop-filter: blur(20px);
  background: var(--glass-bg);
  border: 1px solid var(--border);
}
.premium-card {
  transition: transform .3s cubic-bezier(.4,0,.2,1), box-shadow .3s cubic-bezier(.4,0,.2,1), border-color .3s cubic-bezier(.4,0,.2,1);
}
.premium-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 8px 32px rgba(0,204,0,0.15);
  border-color: rgba(0,204,0,0.3);
}
.glow-button {
  box-shadow: 0 0 20px rgba(0,204,0,0.4);
  transition: all .3s cubic-bezier(.4,0,.2,1);
}
.glow-button:hover {
  box-shadow: 0 0 30px rgba(0,204,0,0.6);
  transform: translateY(-2px);
}
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; cursor: pointer; border: none; transition: all .3s;
  font-family: var(--font-body);
}
.btn-green { background: var(--green); color: #000; padding: .75rem 2rem; border-radius: 9999px; }
.btn-green:hover { background: var(--green-hover); }
.btn-outline {
  background: rgba(255,255,255,0.05); color: var(--text-primary);
  border: 1px solid var(--border); padding: .75rem 2rem; border-radius: 9999px;
}
body.light-mode .btn-outline { background: rgba(0,0,0,0.04); }
.btn-outline:hover { background: rgba(0,204,0,0.08); border-color: var(--green); }

.section-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(0,204,0,0.08); backdrop-filter: blur(12px);
  border: 1px solid rgba(0,204,0,0.2); padding: .5rem 1rem; border-radius: 9999px;
  font-size: .75rem; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--green); margin-bottom: 1rem;
}
.section-title {
  font-size: clamp(2rem, 5vw, 3rem); font-weight: 700;
  color: var(--text-primary); letter-spacing: -.02em; line-height: 1.1;
}
.section-desc {
  font-size: 1rem; color: var(--text-secondary); max-width: 40rem; margin: 0 auto; line-height: 1.7;
}
.text-center { text-align: center; }
.dot-green { width: 6px; height: 6px; border-radius: 50%; background: var(--green); flex-shrink: 0; }

/* ===== DARK/LIGHT TOGGLE PILL ===== */
.theme-toggle {
  background: none; border: none; padding: 0;
  cursor: pointer; flex-shrink: 0; line-height: 0;
}
.toggle-track {
  position: relative; display: flex; align-items: center;
  width: 3.25rem; height: 1.75rem;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 9999px; padding: 0 .25rem;
  transition: background .3s, border-color .3s;
}
.theme-toggle:hover .toggle-track { border-color: rgba(255,255,255,0.2); }
body.light-mode .theme-toggle:hover .toggle-track { border-color: rgba(0,0,0,0.2); }
.toggle-icon {
  display: flex; align-items: center; justify-content: center;
  width: 1rem; height: 1rem; flex-shrink: 0; color: var(--text-muted);
  transition: opacity .2s;
}
.toggle-icon svg { width: .75rem; height: .75rem; }
.toggle-icon--moon { margin-right: auto; }
.toggle-icon--sun  { margin-left: auto; }
/* dark mode: moon visible, sun faded */
.toggle-icon--moon { opacity: 1; }
.toggle-icon--sun  { opacity: .35; }
/* light mode: sun visible, moon faded */
body.light-mode .toggle-icon--moon { opacity: .35; }
body.light-mode .toggle-icon--sun  { opacity: 1; color: #F59E0B; }
/* sliding knob */
.toggle-knob {
  position: absolute; top: 50%; left: .2rem;
  transform: translateY(-50%);
  width: 1.2rem; height: 1.2rem; border-radius: 50%;
  background: var(--text-muted);
  transition: left .25s cubic-bezier(.4,0,.2,1), background .25s;
  pointer-events: none;
}
body.light-mode .toggle-knob {
  left: calc(100% - 1.4rem);
  background: #F59E0B;
}

/* ===== HEADER ===== */
#site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border-bottom: 1px solid var(--border);
  transition: background .3s ease, border-color .3s ease;
}
#site-header .container { position: relative; }
/* Push fixed header down when WP admin bar is present */
.admin-bar #site-header { top: 32px; }
@media screen and (max-width: 782px) { .admin-bar #site-header { top: 46px; } }
.header-inner {
  display: flex; align-items: center; justify-content: space-between; height: 5rem;
}
.site-logo img { height: 2rem; width: auto; }
.main-nav { display: flex; align-items: center; gap: 2rem; }
.main-nav a { font-size: .875rem; font-weight: 500; color: var(--text-muted); transition: color .2s; }
.main-nav a:hover,
.main-nav a[aria-current="page"] { color: var(--green); }
.header-ctas { display: flex; align-items: center; gap: 1rem; position: relative; }

/* ===== WHATSAPP ICON BUTTON ===== */
.btn-wa-icon {
  display: flex; align-items: center; justify-content: center;
  width: 2.25rem; height: 2.25rem; border-radius: 50%;
  background: rgba(37,211,102,0.12); color: #25D366;
  border: 1px solid rgba(37,211,102,0.35);
  cursor: pointer; transition: background .2s, border-color .2s;
  flex-shrink: 0;
}
.btn-wa-icon:hover { background: rgba(37,211,102,0.22); border-color: #25D366; }

/* mobile-right: WA + hamburger side by side */
.mobile-right { display: none; align-items: center; gap: .5rem; }
@media(max-width:768px){
  .header-ctas { display: none; }
  .mobile-right { display: flex; }
  .mobile-toggle { display: flex; }
}

/* ===== WHATSAPP POPUP ===== */
.wa-popup {
  position: absolute; top: 100%; right: 0;
  width: 17rem; z-index: 9999;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 1rem; overflow: hidden;
  box-shadow: 0 12px 40px rgba(0,0,0,0.3);
  animation: waFadeIn .18s ease;
}
@media(max-width:480px){
  .wa-popup { right: 0; left: 0; width: auto; max-width: none; }
}
@keyframes waFadeIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.wa-popup-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .75rem 1rem;
  background: linear-gradient(135deg, #075E54, #128C7E);
}
.wa-popup-title { font-size: .8rem; font-weight: 700; color: #fff; letter-spacing: .05em; text-transform: uppercase; }
.wa-popup-close {
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,0.7); display: flex; align-items: center;
  padding: .15rem; transition: color .2s;
}
.wa-popup-close:hover { color: #fff; }
.wa-popup-body { padding: 1rem; }
.wa-agent { display: flex; gap: .75rem; align-items: flex-start; margin-bottom: 1rem; }
.wa-agent-avatar {
  position: relative; flex-shrink: 0;
  width: 2.75rem; height: 2.75rem; border-radius: 50%;
  background: linear-gradient(135deg, #25D366, #128C7E);
  display: flex; align-items: center; justify-content: center;
}
.wa-avatar-initials { font-size: .875rem; font-weight: 700; color: #fff; }
.wa-online-dot {
  position: absolute; bottom: 1px; right: 1px;
  width: .65rem; height: .65rem; border-radius: 50%;
  background: #25D366; border: 2px solid var(--bg-secondary);
}
.wa-agent-info { display: flex; flex-direction: column; gap: .15rem; }
.wa-agent-info strong { font-size: .9rem; color: var(--text-primary); }
.wa-agent-role { font-size: .75rem; color: #25D366; font-weight: 500; }
.wa-agent-meta { display: flex; flex-direction: column; gap: .3rem; margin-top: .4rem; }
.wa-meta-item { display: flex; align-items: center; gap: .35rem; font-size: .7rem; color: var(--text-muted); }
.wa-meta-item svg { flex-shrink: 0; }
.wa-send-btn {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  width: 100%; padding: .65rem 1rem; border-radius: 9999px;
  background: #25D366; color: #fff; font-weight: 700; font-size: .875rem;
  transition: background .2s; text-decoration: none;
}
.wa-send-btn:hover { background: #20b858; }
.mobile-toggle { display: none; background: none; border: none; color: var(--text-primary); cursor: pointer; }
.mobile-menu { display: none; padding: 1.5rem 0; border-top: 1px solid var(--border); }
.mobile-menu.open { display: block; }
.mobile-menu > a,
.mobile-menu > .mobile-nav-group,
.mobile-nav-link { display: block; margin-bottom: .75rem; }
.mobile-menu > a { font-size: 1rem; font-weight: 500; color: var(--text-primary); transition: color .2s; }
.mobile-menu > a:hover, .mobile-menu > a[aria-current="page"] { color: var(--green); }
.mobile-menu .mobile-ctas { display: flex; flex-direction: column; gap: .5rem; margin-top: 1rem; }
.mobile-menu .mobile-ctas .btn { width: 100%; }
@media(max-width:768px){
  .main-nav, .header-ctas { display: none; }
  .mobile-toggle { display: block; }
}

/* ===== DESKTOP DROPDOWN NAV ===== */
.nav-dropdown-wrap { position: relative; display: inline-flex; align-items: center; gap: .15rem; }
.nav-dropdown-parent {
  font-size: .875rem; font-weight: 500; color: var(--text-muted); transition: color .2s;
}
.nav-dropdown-parent:hover, .nav-dropdown-parent[aria-current="page"] { color: var(--green); }.nav-dropdown-toggle {
  display: flex; align-items: center;
  background: none; border: none; cursor: pointer; padding: .1rem .15rem;
  color: var(--text-muted); transition: color .2s, transform .2s;
}
.nav-dropdown-toggle:hover { color: var(--green); }
.nav-dropdown-toggle svg { transition: transform .2s; }
.nav-dropdown-toggle[aria-expanded="true"] svg { transform: rotate(180deg); }
.nav-dropdown-toggle[aria-expanded="true"] { color: var(--green); }
.nav-dropdown {
  position: absolute; top: calc(100% + .75rem); left: 50%; transform: translateX(-50%);
  min-width: 14rem; background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: .75rem; padding: .5rem; list-style: none;
  box-shadow: 0 8px 32px var(--shadow);
  opacity: 0; visibility: hidden; transform: translateX(-50%) translateY(-8px);
  transition: opacity .2s, transform .2s, visibility .2s;
  z-index: 200;
}
.nav-dropdown-wrap:hover .nav-dropdown,
.nav-dropdown-wrap:focus-within .nav-dropdown,
.nav-dropdown.open {
  opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
}
.nav-dropdown li a {
  display: block; padding: .5rem .875rem; border-radius: .5rem;
  font-size: .875rem; color: var(--text-muted); transition: background .15s, color .15s;
}
.nav-dropdown li a:hover { background: rgba(0,204,0,0.08); color: var(--green); }

/* ===== MOBILE DROPDOWN NAV ===== */
.mobile-nav-group { display: flex; flex-direction: column; }
.mobile-nav-parent-row {
  display: flex; align-items: center; justify-content: space-between;
}
.mobile-nav-parent-link {
  font-size: 1rem; font-weight: 500; color: var(--text-primary); transition: color .2s;
}
.mobile-nav-parent-link:hover,
.mobile-nav-parent-link[aria-current="page"] { color: var(--green); }
.mobile-nav-toggle {
  background: none; border: none; cursor: pointer; padding: .25rem;
  color: var(--text-muted); display: flex; align-items: center; transition: color .2s;
}
.mobile-nav-toggle:hover { color: var(--green); }
.mobile-nav-toggle svg { transition: transform .2s; }
.mobile-nav-toggle[aria-expanded="true"] svg { transform: rotate(180deg); }
.mobile-nav-children { display: none; flex-direction: column; gap: .5rem; padding-left: 1rem; margin-top: .5rem; }
.mobile-nav-children.open { display: flex; }
.mobile-nav-link {
  display: block; font-size: 1rem; font-weight: 500;
  color: var(--text-primary); transition: color .2s;
}
.mobile-nav-link:hover,
.mobile-nav-link[aria-current="page"] { color: var(--green); }
.mobile-nav-child { font-size: .9rem; color: var(--text-muted); transition: color .2s; }
.mobile-nav-child:hover { color: var(--green); }

/* ===== INQUIRY SECTION ===== */
.inquiry-section { padding: 6rem 0; background: var(--bg-secondary); }
.inquiry-wrap { display: grid; grid-template-columns: 1fr 1.6fr; gap: 4rem; align-items: start; }
.inquiry-info .section-title { font-size: clamp(1.75rem,4vw,2.5rem); margin-bottom: 1rem; }
.inquiry-info > p { font-size: 1rem; color: var(--text-secondary); line-height: 1.7; margin-bottom: 1.5rem; }
.inquiry-perks { display: flex; flex-direction: column; gap: .75rem; }
.inquiry-perks li { display: flex; align-items: center; gap: .5rem; font-size: .875rem; color: var(--text-secondary); }
.inquiry-form-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 2rem;
}
@media(max-width:1024px){ .inquiry-wrap { grid-template-columns: 1fr; gap: 2rem; } }

/* ===== HERO – plain, no bg image ===== */
#hero {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-primary);
  position: relative; overflow: hidden;
}
/* subtle grid pattern overlay */
#hero::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='g' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M 10 0 L 0 0 0 10' fill='none' stroke='rgba(0,204,0,0.04)' stroke-width='1'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='100%25' height='100%25' fill='url(%23g)'/%3E%3C/svg%3E");
}
/* green radial glow top-center */
#hero::after {
  content: '';
  position: absolute; top: -10rem; left: 50%; transform: translateX(-50%);
  width: 60rem; height: 40rem; pointer-events: none;
  background: radial-gradient(ellipse at center, rgba(0,204,0,0.07) 0%, transparent 70%);
}
body.light-mode #hero::after {
  background: radial-gradient(ellipse at center, rgba(0,204,0,0.05) 0%, transparent 70%);
}
.hero-content {
  position: relative; z-index: 10; text-align: center;
  padding: 10rem 1.5rem 6rem; max-width: 56rem; margin: 0 auto;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: .75rem;
  background: rgba(0,204,0,0.08); backdrop-filter: blur(12px);
  border: 1px solid rgba(0,204,0,0.2); padding: .75rem 1.5rem; border-radius: 9999px;
  margin-bottom: 2rem;
}
.hero-badge span { font-size: .75rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--green); }
.hero-title {
  font-size: clamp(2.5rem, 8vw, 4.5rem); font-weight: 900;
  letter-spacing: -.04em; line-height: 1.1; margin-bottom: 1.5rem;
}
.hero-title span:not(.gradient-text-accent) { color: var(--text-primary); }

/* rotating headline */
.hero-rotating-wrap { display: block; overflow: hidden; }
.hero-rotating { display: block; position: relative; }
.hero-word {
  display: block;
  position: absolute; top: 0; left: 0;
  opacity: 0;
  transform: translateY(60%);
  transition: opacity .5s ease, transform .5s ease;
  white-space: nowrap;
}
.hero-word.active {
  opacity: 1;
  transform: translateY(0);
  position: relative;
}
.hero-word.exit {
  opacity: 0;
  transform: translateY(-60%);
  position: absolute;
}
.hero-desc {
  font-size: 1.125rem; color: var(--text-secondary); max-width: 40rem;
  margin: 0 auto 3rem; line-height: 1.7;
}
.hero-btns { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; margin-bottom: 4rem; }
.hero-btns .btn { padding: 1rem 2rem; font-size: 1.125rem; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 2rem; }
.hero-trust-item { display: flex; align-items: center; gap: .5rem; font-size: .875rem; color: var(--text-muted); }
.hero-trust-dot { width: 8px; height: 8px; border-radius: 50%; background: #10B981; }

/* ===== HERO SPLIT LAYOUT ===== */
.hero-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  padding-top: 8rem;
  padding-bottom: 5rem;
}
.hero-split .hero-content {
  text-align: left;
  padding: 0;
  max-width: none;
  margin: 0;
}
.hero-split .hero-btns { justify-content: flex-start; }
.hero-split .hero-trust { 
  justify-content: center;
  margin-top: 20px;
 }

/* ===== HERO VISUAL / BROWSER MOCKUP ===== */
.hero-visual {
  position: relative;
  z-index: 10;
}
.hero-visual-glow {
  position: absolute;
  inset: -2rem;
  background: radial-gradient(ellipse at center, rgba(0,204,0,0.12) 0%, transparent 70%);
  pointer-events: none;
  z-index: -1;
  border-radius: 2rem;
}
.browser-mockup {
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 24px 64px rgba(0,0,0,0.4);
  background: var(--bg-secondary);
  animation: mockupFloat 4s ease-in-out infinite;
}
@keyframes mockupFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-10px); }
}

/* Browser chrome bar */
.browser-bar {
  display: flex; align-items: center; gap: .75rem;
  padding: .625rem 1rem;
  background: var(--bg-primary);
  border-bottom: 1px solid var(--border);
}
.browser-dots { display: flex; gap: .375rem; }
.dot { width: .625rem; height: .625rem; border-radius: 50%; }
.dot-red    { background: #FF5F57; }
.dot-yellow { background: #FFBD2E; }
.dot-green-dot { background: #28C840; }
.browser-url {
  flex: 1; display: flex; align-items: center; gap: .375rem;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 9999px; padding: .25rem .75rem;
  font-size: .7rem; color: var(--text-muted);
}
.browser-actions { color: var(--text-muted); display: flex; align-items: center; }

/* Browser screen */
.browser-screen {
  padding: 1rem;
  background: var(--bg-secondary);
  position: relative;
  min-height: 18rem;
}

/* Mock nav */
.mock-nav {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: .875rem;
}
.mock-logo {
  width: 4rem; height: .625rem; border-radius: 9999px;
  background: linear-gradient(90deg, var(--green), rgba(0,204,0,0.3));
}
.mock-nav-links { display: flex; align-items: center; gap: .5rem; }
.mock-link {
  width: 2rem; height: .5rem; border-radius: 9999px;
  background: var(--border);
}
.mock-btn {
  width: 3rem; height: 1.25rem; border-radius: 9999px;
  background: rgba(0,204,0,0.25);
}

/* Mock hero area */
.mock-hero-area { margin-bottom: 1rem; }
.mock-headline {
  height: .875rem; border-radius: 9999px;
  background: var(--text-primary); opacity: .15;
  margin-bottom: .5rem;
}
.mock-headline--short { width: 60%; }
.mock-subtext {
  height: .5rem; border-radius: 9999px;
  background: var(--text-muted); opacity: .25;
  margin-bottom: .375rem;
}
.mock-subtext--short { width: 75%; }
.mock-cta-row { display: flex; gap: .5rem; margin-top: .75rem; }
.mock-cta {
  height: 1.5rem; border-radius: 9999px;
  width: 5rem;
}
.mock-cta--primary { background: var(--green); opacity: .8; }
.mock-cta--outline { background: transparent; border: 1px solid var(--border); }

/* Mock cards row */
.mock-cards-row { display: grid; grid-template-columns: repeat(3,1fr); gap: .5rem; }
.mock-card {
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: .5rem; padding: .625rem;
}
.mock-card--active { border-color: rgba(0,204,0,0.4); background: rgba(0,204,0,0.05); }
.mock-card-icon {
  width: 1.25rem; height: 1.25rem; border-radius: .25rem;
  background: var(--border); margin-bottom: .375rem;
}
.mock-card-icon--green { background: rgba(0,204,0,0.3); }
.mock-card-line {
  height: .375rem; border-radius: 9999px;
  background: var(--border); margin-bottom: .25rem;
}
.mock-card-line--short { width: 60%; }

/* Floating badge overlays on browser screen */
.mock-badge {
  position: absolute;
  display: flex; align-items: center; gap: .375rem;
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: .5rem; padding: .375rem .625rem;
  font-size: .7rem; font-weight: 600; color: var(--text-primary);
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  white-space: nowrap;
}
.mock-badge svg { color: var(--green); flex-shrink: 0; }
.mock-badge--tl { top: .75rem; left: .75rem; animation: badgePop 3s ease-in-out infinite; }
.mock-badge--br { bottom: .75rem; right: .75rem; animation: badgePop 3s ease-in-out infinite .5s; }
@keyframes badgePop {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.05); }
}

/* Responsive */
@media(max-width:1024px) {
  .hero-split {
    grid-template-columns: 1fr;
    gap: 3rem;
    padding-top: 7rem;
  }
  .hero-split .hero-content { text-align: center; }
  .hero-split .hero-btns { justify-content: center; }
  .hero-split .hero-trust { justify-content: center; }
  .hero-visual { max-width: 36rem; margin: 0 auto; }
}
@media(max-width:640px) {
  .mock-cards-row { grid-template-columns: repeat(2,1fr); }
  .mock-card:last-child { display: none; }
}

/* floating metric badges */
.metric-badges { position: absolute; inset: 0; z-index: 5; pointer-events: none; }
.metric-badge {
  position: absolute; backdrop-filter: blur(12px);
  background: var(--glass-bg); border: 1px solid var(--border);
  box-shadow: 0 4px 16px var(--shadow); border-radius: 1rem; padding: 1rem;
  display: flex; align-items: center; gap: .75rem;
}
.metric-badge .val { font-size: 1.5rem; font-weight: 900; color: var(--text-primary); }
.metric-badge .lbl { font-size: .75rem; color: var(--text-muted); }
.metric-badge svg { color: var(--green); }
@media(max-width:1024px){ .metric-badge { display: none; } }

/* ===== METRICS RIBBON ===== */
#metrics-ribbon {
  padding: 3rem 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  background: var(--bg-secondary);
}
.metrics-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; text-align: center; }
.metric-item .icon { color: var(--green); margin: 0 auto .75rem; }
.metric-item .value { font-size: 2.5rem; font-weight: 900; color: var(--text-primary); font-family: var(--font-heading); }
.metric-item .label { font-size: .875rem; color: var(--text-muted); }
@media(max-width:640px){ .metrics-grid { grid-template-columns: repeat(2,1fr); } }

/* ===== SERVICES SECTION ===== */
#services-section { padding: 6rem 0; background: var(--bg-primary); }
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.service-card {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 1rem; overflow: hidden;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.service-card-body .svc-flag {
    position: absolute;
    right: 20px;
    top: 20px;
}
.service-card:hover { transform: translateY(-8px); box-shadow: 0 8px 32px rgba(0,204,0,0.12); border-color: rgba(0,204,0,0.3); }
.service-card-img { position: relative; height: 12rem; overflow: hidden; }
.service-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.service-card:hover .service-card-img img { transform: scale(1.1); }
.service-card-img-overlay { position: absolute; inset: 0; background: linear-gradient(to top, var(--bg-secondary), transparent); }
.service-card-body { padding: 2rem; }
.service-icon-wrap {
  background: rgba(0,204,0,0.1); width: 3.5rem; height: 3.5rem;
  border-radius: .75rem; display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.5rem; color: var(--green);
}
.service-card h3 { font-size: 1.25rem; font-weight: 700; color: var(--text-primary); margin-bottom: .75rem; }
.service-card p { font-size: .875rem; color: var(--text-muted); margin-bottom: 1rem; line-height: 1.6; }
.service-features { margin-bottom: 1.5rem; }
.service-features li { display: flex; align-items: center; gap: .5rem; font-size: .875rem; color: var(--text-secondary); margin-bottom: .5rem; }
.service-features li svg { flex-shrink: 0; }
.service-link { color: var(--green); font-size: .875rem; font-weight: 600; transition: color .2s; }
.service-link:hover { color: var(--text-primary); }
.services-cta { text-align: center; margin-top: 3rem; }
@media(max-width:1024px){ .services-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px){ .services-grid { grid-template-columns: 1fr; } }

/* ===== WHY TWEAKINFO ===== */
#why-tweakinfo { padding: 6rem 0; background: var(--bg-secondary); }
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.why-image { border-radius: 1rem; overflow: hidden; border: 1px solid var(--border); }
.why-image img { width: 100%; height: 100%; object-fit: cover; }
.why-content h2 { margin-bottom: 1.5rem; }
.why-content > p { font-size: 1rem; color: var(--text-secondary); margin-bottom: 2rem; line-height: 1.7; }
.why-reasons { display: flex; flex-direction: column; gap: 1.5rem; }
.why-reason { display: flex; gap: 1rem; }
.why-reason-icon {
  background: rgba(0,204,0,0.1); width: 3rem; height: 3rem;
  border-radius: .75rem; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--green);
}
.why-reason h4 { font-weight: 600; color: var(--text-primary); margin-bottom: .5rem; }
.why-reason p { font-size: .875rem; color: var(--text-muted); line-height: 1.6; }
@media(max-width:1024px){ .why-grid { grid-template-columns: 1fr; } .why-image { order: 2; } .why-content { order: 1; } }

/* ===== PRICING ===== */
#pricing { padding: 6rem 0; background: var(--bg-secondary); }
.pricing-tabs { display: flex; justify-content: center; margin-bottom: 3rem; }
.pricing-tab-list {
  display: grid; grid-template-columns: repeat(3,1fr);
  background: var(--glass-bg); border: 1px solid var(--border);
  border-radius: .75rem; padding: .25rem; max-width: 28rem; width: 100%;
}
.pricing-tab {
  padding: .625rem 1rem; border-radius: .5rem; font-size: .875rem; font-weight: 500;
  color: var(--text-muted); cursor: pointer; border: none; background: none;
  transition: all .2s; text-align: center;
}
.pricing-tab.active { background: var(--green); color: #000; font-weight: 700; }
.pricing-panel { display: none; }
.pricing-panel.active { display: block; }
.pricing-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.pricing-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 2rem;
  position: relative; transition: all .3s;
}
.pricing-card.popular { border: 2px solid var(--green); }
.popular-badge {
  position: absolute; top: -1rem; left: 50%; transform: translateX(-50%);
  background: var(--green); color: #000; font-weight: 700; font-size: .75rem;
  padding: .25rem 1rem; border-radius: 9999px; display: flex; align-items: center; gap: .25rem;
  white-space: nowrap;
}
.pricing-card h3 { font-size: 1.5rem; font-weight: 700; color: var(--text-primary); margin-bottom: .5rem; }
.pricing-price { margin-bottom: 1.5rem; }
.pricing-price .amount { font-size: 3rem; font-weight: 900; color: var(--text-primary); }
.pricing-price .period { color: var(--text-muted); margin-left: .5rem; }
.pricing-price .yearly-note { font-size: .875rem; color: var(--text-muted); margin-top: .25rem; }
.pricing-features { margin-bottom: 2rem; }
.pricing-features li { display: flex; align-items: flex-start; gap: .75rem; font-size: .875rem; color: var(--text-secondary); margin-bottom: .75rem; }
.pricing-features li svg { color: var(--green); flex-shrink: 0; margin-top: 2px; }
.billing-toggle { display: flex; justify-content: center; margin-bottom: 2rem; }
.billing-toggle-inner {
  display: inline-flex; background: var(--glass-bg); border: 1px solid var(--border);
  border-radius: 9999px; padding: .25rem;
}
.billing-btn {
  padding: .5rem 1.5rem; border-radius: 9999px; font-size: .875rem; font-weight: 500;
  cursor: pointer; border: none; background: none; color: var(--text-muted); transition: all .2s;
}
.billing-btn.active { background: var(--green); color: #000; font-weight: 700; }
@media(max-width:1024px){ .pricing-grid { grid-template-columns: 1fr; max-width: 28rem; margin: 0 auto; } }
@media(max-width:640px){ .pricing-tab-list { grid-template-columns: 1fr; max-width: 100%; } }

/* ===== CUSTOM QUOTE FORM ===== */
.quote-form-wrap {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 2rem;
  max-width: 48rem; margin: 0 auto;
}
.quote-form-wrap h3 { font-size: 1.875rem; font-weight: 700; color: var(--text-primary); text-align: center; margin-bottom: .5rem; }
.quote-form-wrap .subtitle { font-size: .875rem; color: var(--text-muted); text-align: center; margin-bottom: 2rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.form-group { margin-bottom: 1.5rem; }
.form-group label { display: block; font-size: .875rem; color: var(--text-primary); margin-bottom: .5rem; font-weight: 500; }
.form-group input, .form-group textarea, .form-group select {
  width: 100%; background: var(--glass-bg); border: 1px solid var(--border);
  border-radius: .5rem; padding: .625rem .875rem; color: var(--text-primary); font-size: .875rem;
  font-family: var(--font-body); transition: border-color .2s;
}
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--text-muted); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--green); }
.form-group select option { background: var(--bg-secondary); color: var(--text-primary); }
.features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
.feature-check { display: flex; align-items: center; gap: .5rem; }
.feature-check input[type=checkbox] { accent-color: var(--green); width: 1rem; height: 1rem; cursor: pointer; }
.feature-check label { font-size: .875rem; color: var(--text-secondary); cursor: pointer; }
.form-note { font-size: .75rem; color: var(--text-muted); text-align: center; margin-top: .75rem; }
@media(max-width:640px){ .form-row { grid-template-columns: 1fr; } .features-grid { grid-template-columns: repeat(2,1fr); } }

/* ===== TESTIMONIALS ===== */
#testimonials { padding: 6rem 0; background: var(--bg-primary); overflow: hidden; }
.testimonials-track-wrap { overflow: hidden; position: relative; }
.testimonials-track {
  display: flex; gap: 1rem; width: max-content;
  animation: marquee 40s linear infinite;
}
.testimonials-track:hover { animation-play-state: paused; }
@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.testimonial-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 2rem;
  width: 25rem; flex-shrink: 0; position: relative;
}
.testimonial-quote { position: absolute; top: 1.5rem; right: 1.5rem; color: var(--green); opacity: .2; }
.testimonial-stars { display: flex; gap: .25rem; margin-bottom: 1rem; color: var(--green); }
.testimonial-text { font-size: .875rem; color: var(--text-secondary); line-height: 1.7; margin-bottom: 1.5rem; }
.testimonial-author { border-top: 1px solid var(--border); padding-top: 1rem; }
.testimonial-author .name { font-weight: 600; color: var(--text-primary); }
.testimonial-author .role { font-size: .75rem; color: var(--text-muted); }

/* ===== CTA SECTION ===== */
.cta-section {
  position: relative; padding: 6rem 0; overflow: hidden;
  background: linear-gradient(135deg, #4338CA, #111827, #0A0F1C);
}
body.light-mode .cta-section {
  background: linear-gradient(135deg, #4338CA, #1E293B, #0F172A);
}
.cta-grid-overlay {
  position: absolute; inset: 0; opacity: .2;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='grid' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M 10 0 L 0 0 0 10' fill='none' stroke='rgba(255,255,255,0.05)' stroke-width='1'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='100%25' height='100%25' fill='url(%23grid)'/%3E%3C/svg%3E");
}
.cta-content { position: relative; z-index: 10; max-width: 48rem; margin: 0 auto; text-align: center; }
.cta-icon { color: var(--green); margin: 0 auto 1.5rem; }
.cta-content h2 { font-size: clamp(2rem,5vw,3rem); font-weight: 700; color: #fff; margin-bottom: 1.5rem; }
.cta-content p { font-size: 1rem; color: rgba(255,255,255,0.75); margin-bottom: 2rem; line-height: 1.7; }
.cta-btns { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }
.cta-btns .btn-outline {
  color: #fff;
  border-color: rgba(255,255,255,0.4);
  background: rgba(255,255,255,0.08);
}
.cta-btns .btn-outline:hover { background: rgba(255,255,255,0.15); border-color: rgba(255,255,255,0.6); }
.cta-note { font-size: .875rem; color: rgba(255,255,255,0.5); margin-top: 1.5rem; }

/* ===== FOOTER ===== */
#site-footer { background: var(--bg-primary); border-top: 1px solid var(--border); }
.footer-inner { padding: 6rem 0 2rem; }
.footer-grid { display: grid; grid-template-columns: 2fr 1.5fr 1fr 1.5fr; gap: 3rem; margin-bottom: 4rem; }
.footer-brand img { height: 2rem; width: auto; margin-bottom: 1rem; }
.footer-brand p { font-size: .875rem; color: var(--text-muted); line-height: 1.7; max-width: 20rem; margin-bottom: 1.5rem; }
.footer-tech-icons { display: flex; gap: 1rem; color: var(--green); margin-bottom: 1rem; }
.footer-tech-icons svg { transition: color .2s; cursor: pointer; }
.footer-tech-icons svg:hover { color: var(--text-primary); }
.footer-social { display: flex; gap: .75rem; }
.footer-social a {
  background: var(--glass-bg); border: 1px solid var(--border);
  padding: .5rem; border-radius: .5rem; transition: all .2s; color: var(--text-muted);
  display: flex; align-items: center; justify-content: center;
}
.footer-social a:hover { background: rgba(0,204,0,0.1); color: var(--green); }
.footer-col h4, .footer-col-heading { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-primary); margin-bottom: 1rem; }
.footer-col ul li { margin-bottom: .75rem; }
.footer-col ul li a { font-size: .875rem; color: var(--text-muted); transition: color .2s; }
.footer-col ul li a:hover { color: var(--green); }
.footer-col ul li span { font-size: .875rem; color: var(--text-muted); }
.footer-bottom {
  border-top: 1px solid var(--border); padding-top: 2rem;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 1rem; font-size: .875rem; color: var(--text-muted);
}
.footer-bottom-links { display: flex; gap: 1.5rem; }
.footer-bottom-links a { color: var(--text-muted); transition: color .2s; }
.footer-bottom-links a:hover { color: var(--green); }
@media(max-width:1024px){ .footer-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:640px){
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .footer-inner { padding-left: 1.5rem; padding-right: 1.5rem; }
}

/* ===== INNER PAGE HERO ===== */
.page-hero { padding: 10rem 0 6rem; background: var(--bg-primary); position: relative; overflow: hidden; }
.page-hero::before {
  content: ''; position: absolute; inset: 0; opacity: .15; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='grid' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M 10 0 L 0 0 0 10' fill='none' stroke='rgba(0,204,0,0.06)' stroke-width='1'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='100%25' height='100%25' fill='url(%23grid)'/%3E%3C/svg%3E");
}
.page-hero-content { position: relative; z-index: 10; max-width: 48rem; margin: 0 auto; text-align: center; }
.page-hero-content h1 { font-size: clamp(2.5rem,6vw,3.75rem); font-weight: 700; color: var(--text-primary); margin-bottom: 1.5rem; line-height: 1.1; }
.page-hero-content p { font-size: 1rem; color: var(--text-secondary); line-height: 1.7; }

/* ===== ABOUT PAGE ===== */
.stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; margin-top: 4rem; }
.stat-card {
  text-align: center; backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 1.5rem;
}
.stat-card .val { font-size: 2.5rem; font-weight: 900; color: var(--green); font-family: var(--font-heading); margin-bottom: .5rem; }
.stat-card .lbl { font-size: .875rem; color: var(--text-muted); }
.values-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.value-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 2rem;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.value-card:hover { transform: translateY(-6px); box-shadow: 0 8px 32px rgba(0,204,0,0.1); border-color: rgba(0,204,0,0.3); }
.value-icon-wrap {
  background: rgba(0,204,0,0.1); width: 3.5rem; height: 3.5rem;
  border-radius: .75rem; display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.5rem; color: var(--green);
}
.value-card h3 { font-size: 1.5rem; font-weight: 700; color: var(--text-primary); margin-bottom: 1rem; }
.value-card p { font-size: .875rem; color: var(--text-secondary); line-height: 1.7; }
.story-section { padding: 6rem 0; background: var(--bg-primary); }
.story-content { max-width: 56rem; margin: 0 auto; }
.story-content h2 { font-size: clamp(2rem,5vw,3rem); font-weight: 700; color: var(--text-primary); margin-bottom: 2rem; }
.story-content p { font-size: 1rem; color: var(--text-secondary); line-height: 1.7; margin-bottom: 1.5rem; }
.story-box {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 2rem; margin-top: 3rem;
}
.story-box h3 { font-size: 1.25rem; font-weight: 600; color: var(--text-primary); margin-bottom: 1rem; }
.story-box p { font-size: .875rem; color: var(--text-secondary); line-height: 1.7; }
@media(max-width:1024px){ .stats-grid { grid-template-columns: repeat(2,1fr); } .values-grid { grid-template-columns: 1fr; } }

/* ===== SERVICES PAGE ===== */
.all-services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.all-service-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 2rem; transition: all .3s;
}
.all-service-card:hover { transform: translateY(-8px); box-shadow: 0 8px 32px rgba(0,204,0,0.12); border-color: rgba(0,204,0,0.3); }
.all-service-card h3 { font-size: 1.25rem; font-weight: 700; color: var(--text-primary); margin-bottom: .75rem; }
.all-service-card p { font-size: .875rem; color: var(--text-muted); margin-bottom: 1rem; line-height: 1.6; }
.all-service-card .learn-more { color: var(--green); font-size: .875rem; font-weight: 600; display: inline-flex; align-items: center; gap: .5rem; transition: color .2s; }
.all-service-card .learn-more:hover { color: var(--text-primary); }
@media(max-width:1024px){ .all-services-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px){ .all-services-grid { grid-template-columns: 1fr; } }

/* ===== CONTACT PAGE ===== */
.contact-hero { background: var(--bg-primary); padding: 8rem 0 4rem; }
.contact-hero h1 { color: var(--text-primary); }
.contact-hero p { color: var(--text-secondary); }
.contact-body { background: var(--bg-secondary); padding: 6rem 0; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
.contact-form-card {
  background: var(--glass-bg); border: 1px solid var(--border); border-radius: .75rem;
  padding: 2rem; box-shadow: 0 1px 8px var(--shadow);
}
.contact-form-card h2 { font-size: 1.5rem; font-weight: 700; color: var(--text-primary); margin-bottom: 1.5rem; }
.contact-form-card .form-group label { color: var(--text-primary); }
.contact-form-card .form-group input,
.contact-form-card .form-group textarea {
  background: var(--glass-bg); border: 1px solid var(--border); color: var(--text-primary);
}
.contact-form-card .form-group input:focus,
.contact-form-card .form-group textarea:focus { border-color: var(--green); }
.contact-form-card .form-group input::placeholder,
.contact-form-card .form-group textarea::placeholder { color: var(--text-muted); }
.contact-info-item { display: flex; gap: 1rem; margin-bottom: 1.5rem; }
.contact-info-icon {
  background: rgba(0,204,0,0.1); width: 3rem; height: 3rem; border-radius: .5rem;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--green);
}
.contact-info-item h4 { font-weight: 600; color: var(--text-primary); margin-bottom: .25rem; }
.contact-info-item a { font-size: .875rem; color: var(--green); }
.contact-info-item p { font-size: .875rem; color: var(--text-secondary); }
.contact-info-item .sub { font-size: .75rem; color: var(--text-muted); margin-top: .25rem; }
.contact-side-card {
  background: var(--glass-bg); border: 1px solid var(--border); border-radius: .75rem;
  padding: 1.5rem; margin-bottom: 1.5rem;
}
.contact-side-card h3 { font-weight: 600; color: var(--text-primary); margin-bottom: 1rem; }
.contact-side-card p { font-size: .875rem; color: var(--text-secondary); margin-bottom: 1rem; }
.btn-blue { background: var(--green); color: #000; padding: .75rem 1.5rem; border-radius: .375rem; width: 100%; display: block; text-align: center; font-weight: 700; transition: background .2s; }
.btn-blue:hover { background: var(--green-hover); }
.btn-outline-gray {
  background: var(--glass-bg); color: var(--text-primary); border: 1px solid var(--border);
  padding: .75rem 1.5rem; border-radius: .375rem; width: 100%; display: block;
  text-align: center; font-weight: 600; transition: all .2s;
}
.btn-outline-gray:hover { border-color: var(--green); color: var(--green); }
.faq-section { background: var(--bg-primary); padding: 6rem 0; }
.faq-section h2 { font-size: clamp(1.75rem,4vw,2.5rem); font-weight: 700; color: var(--text-primary); text-align: center; margin-bottom: 2rem; }
.faq-item { margin-bottom: 1.5rem; }
.faq-item h4 { font-weight: 600; color: var(--text-primary); margin-bottom: .5rem; }
.faq-item p { font-size: .875rem; color: var(--text-secondary); line-height: 1.7; }
@media(max-width:1024px){ .contact-grid { grid-template-columns: 1fr; } }

/* ===== SERVICE DETAIL PAGES ===== */
.service-detail-hero { padding: 10rem 0 6rem; background: var(--bg-primary); position: relative; overflow: hidden; }
.service-detail-hero::before {
  content: ''; position: absolute; inset: 0; opacity: .15; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='grid' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M 10 0 L 0 0 0 10' fill='none' stroke='rgba(0,204,0,0.06)' stroke-width='1'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='100%25' height='100%25' fill='url(%23grid)'/%3E%3C/svg%3E");
}
.service-detail-hero .back-link { display: inline-flex; align-items: center; gap: .5rem; color: var(--green); font-size: .875rem; font-weight: 600; margin-bottom: 1.5rem; transition: color .2s; }
.service-detail-hero .back-link:hover { color: var(--text-primary); }
.service-detail-hero h1 { font-size: clamp(2.5rem,6vw,3.75rem); font-weight: 700; color: var(--text-primary); margin-bottom: 1.5rem; max-width: 48rem; }
.service-detail-hero p { font-size: 1rem; color: var(--text-secondary); margin-bottom: 2rem; max-width: 40rem; line-height: 1.7; }
.service-detail-hero .hero-btns { justify-content: flex-start; margin-bottom: 0; }
.what-we-build-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.process-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 1.5rem; list-style: none; padding: 0; margin: 0; }
.process-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1rem; padding: 1.5rem; text-align: center;
}
.process-step { font-size: 3rem; font-weight: 900; color: var(--green); opacity: .3; margin-bottom: 1rem; font-family: var(--font-heading); display: block; }
.process-card h3, .process-card h4 { font-weight: 600; color: var(--text-primary); margin-bottom: .5rem; font-size: .9rem; }
.process-card p { font-size: .75rem; color: var(--text-muted); line-height: 1.6; }
.tech-tags { display: flex; flex-wrap: wrap; justify-content: center; gap: 1rem; list-style: none; padding: 0; margin: 0; }
.tech-tag {
  display: inline-flex; align-items: center; gap: .5rem;
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 9999px; padding: .75rem 1.5rem;
  font-size: .875rem; font-weight: 600; color: var(--text-primary);
  transition: border-color .2s, color .2s;
}
.tech-tag:hover { border-color: var(--green); color: var(--green); }
.tech-tag-icon { width: 20px; height: 20px; object-fit: contain; border-radius: 3px; flex-shrink: 0; }
@media(max-width:1024px){ .what-we-build-grid { grid-template-columns: 1fr; } .process-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px){ .process-grid { grid-template-columns: 1fr; } }

/* ===== TOAST ===== */
.ti-notice {
  position: fixed; top: 1.5rem; right: 1.5rem; z-index: 9999;
  padding: 1rem 1.5rem; border-radius: .75rem; font-size: .875rem; font-weight: 500;
  max-width: 20rem; box-shadow: 0 4px 16px var(--shadow); animation: slideIn .3s ease;
}
.ti-notice.success { background: #065F46; color: #D1FAE5; border: 1px solid #10B981; }
.ti-notice.error   { background: #7F1D1D; color: #FEE2E2; border: 1px solid #EF4444; }
@keyframes slideIn { from { opacity:0; transform: translateX(2rem); } to { opacity:1; transform: translateX(0); } }

/* ===== SECTION SPACING ===== */
.py-section { padding: 6rem 0; }
.mb-section-head { margin-bottom: 4rem; }

/* ===== START PROJECT PAGE ===== */
.start-project-hero { padding: 8rem 0 3rem; background: var(--bg-primary); text-align: center; }

/* Path selector */
.start-project-paths { padding: 2rem 0 3rem; background: var(--bg-primary); }
.sp-path-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; max-width: 48rem; margin: 0 auto; }
.sp-path-card {
  position: relative; background: var(--bg-secondary); border: 2px solid var(--border);
  border-radius: 1rem; padding: 2rem; text-align: center; cursor: pointer;
  transition: border-color .2s, box-shadow .2s; color: var(--text-primary);
}
.sp-path-card:hover { border-color: rgba(0,204,0,0.4); }
.sp-path-active { border-color: var(--green); box-shadow: 0 0 0 3px rgba(0,204,0,0.1); }
.sp-path-icon { color: var(--green); margin: 0 auto .75rem; display: flex; justify-content: center; }
.sp-path-card h2 { font-size: 1.25rem; font-weight: 700; margin-bottom: .5rem; }
.sp-path-card p { font-size: .875rem; color: var(--text-muted); line-height: 1.6; }
.sp-path-badge {
  display: inline-block; margin-top: .75rem; padding: .2rem .75rem;
  background: rgba(0,204,0,0.1); color: var(--green); border-radius: 9999px;
  font-size: .75rem; font-weight: 700;
}
@media(max-width:640px){ .sp-path-grid { grid-template-columns: 1fr; } }

/* Form section */
.start-project-section { padding: 0 0 6rem; background: var(--bg-primary); }
.sp-form { max-width: 52rem; margin: 0 auto; }

/* Step indicators */
.sp-steps { display: flex; justify-content: center; gap: 0; margin-bottom: 3rem; }
.sp-step {
  display: flex; flex-direction: column; align-items: center; gap: .35rem;
  flex: 1; position: relative;
}
.sp-step::after {
  content: ''; position: absolute; top: 1rem; left: 50%; width: 100%;
  height: 2px; background: var(--border); z-index: 0;
}
.sp-step:last-child::after { display: none; }
.sp-step-num {
  width: 2rem; height: 2rem; border-radius: 50%; border: 2px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 700; background: var(--bg-primary);
  color: var(--text-muted); position: relative; z-index: 1; transition: all .2s;
}
.sp-step-label { font-size: .7rem; color: var(--text-muted); font-weight: 500; }
.sp-step-active .sp-step-num { border-color: var(--green); background: var(--green); color: #000; }
.sp-step-active .sp-step-label { color: var(--green); }
.sp-step-done .sp-step-num { border-color: var(--green); background: rgba(0,204,0,0.15); color: var(--green); }
.sp-step-done::after { background: var(--green); }
@media(max-width:480px){ .sp-step-label { display: none; } }

/* Panels */
.sp-panel { display: none; }
.sp-panel-active { display: block; }
.sp-panel h3 { font-size: 1.375rem; font-weight: 700; color: var(--text-primary); margin-bottom: 1.5rem; }

/* Option grid */
.sp-option-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr)); gap: .75rem; }
.sp-option-grid--sm { grid-template-columns: repeat(auto-fill, minmax(8rem, 1fr)); }
.sp-option-grid .sp-option--wide { grid-column: 1 / -1; }
.sp-option { cursor: pointer; }
.sp-option input { position: absolute; opacity: 0; width: 0; height: 0; }
.sp-option-inner {
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  padding: 1rem .75rem; border-radius: .75rem; border: 1px solid var(--border);
  background: var(--bg-secondary); font-size: .875rem; font-weight: 500;
  color: var(--text-secondary); text-align: center; transition: all .2s;
}
.sp-option-grid--sm .sp-option-inner { flex-direction: row; justify-content: center; padding: .75rem 1rem; }
.sp-option input:checked + .sp-option-inner {
  border-color: var(--green); background: rgba(0,204,0,0.08); color: var(--green);
}
.sp-option-inner:hover { border-color: rgba(0,204,0,0.4); }

/* Fields */
.sp-field-group { display: flex; flex-direction: column; gap: .5rem; }
.sp-label { font-size: .875rem; font-weight: 600; color: var(--text-primary); }
.sp-req { color: var(--green); }
.sp-input {
  width: 100%; background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: .5rem; padding: .75rem 1rem; color: var(--text-primary);
  font-size: .875rem; font-family: var(--font-body); transition: border-color .2s;
}
.sp-input:focus { outline: none; border-color: var(--green); }
.sp-input::placeholder { color: var(--text-muted); }
.sp-textarea { resize: vertical; min-height: 8rem; }
.sp-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
@media(max-width:640px){ .sp-form-row { grid-template-columns: 1fr; } }

/* Nav */
.sp-form-nav { display: flex; gap: 1rem; margin-top: 2rem; justify-content: flex-end; }
.sp-form-msg { margin-top: 1rem; font-size: .875rem; min-height: 1.5rem; text-align: center; }
.sp-form-msg.success { color: #10B981; }
.sp-form-msg.error   { color: #EF4444; }

/* Packages */
.sp-pkg-filters { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 2rem; justify-content: center; }
.sp-pkg-filter {
  padding: .5rem 1.25rem; border-radius: 9999px; border: 1px solid var(--border);
  background: var(--bg-secondary); color: var(--text-muted); font-size: .875rem;
  cursor: pointer; transition: all .2s;
}
.sp-pkg-filter:hover, .sp-pkg-filter-active { border-color: var(--green); color: var(--green); background: rgba(0,204,0,0.08); }
.sp-pkg-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.sp-pkg-card {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 1rem; padding: 2rem; transition: transform .3s, box-shadow .3s, border-color .3s;
}
.sp-pkg-card:hover { transform: translateY(-6px); box-shadow: 0 8px 32px rgba(0,204,0,0.12); border-color: rgba(0,204,0,0.3); }
.sp-pkg-card h3 { font-size: 1.125rem; font-weight: 700; color: var(--text-primary); margin-bottom: .75rem; }
.sp-pkg-price { font-size: 1.75rem; font-weight: 900; color: var(--green); margin-bottom: 1rem; }
.sp-pkg-features { list-style: none; margin-bottom: 1.5rem; display: flex; flex-direction: column; gap: .5rem; }
.sp-pkg-features li { display: flex; align-items: center; gap: .5rem; font-size: .875rem; color: var(--text-secondary); }
.sp-pkg-btn { width: 100%; justify-content: center; }
.sp-pkg-card.sp-hidden { display: none; }
@media(max-width:1024px){ .sp-pkg-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px){ .sp-pkg-grid { grid-template-columns: 1fr; } }

/* ── Start Project form updates ── */
.sp-form-section { padding: 3rem 0 6rem; background: var(--bg-primary); }
.sp-sublabel { font-size: 1rem; font-weight: 600; color: var(--text-primary); margin-bottom: 1rem; }
.sp-checkbox-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr)); gap: .75rem; }
.sp-checkbox { cursor: pointer; }
.sp-checkbox input { position: absolute; opacity: 0; width: 0; height: 0; }
.sp-checkbox-inner {
  display: flex; align-items: center; justify-content: center; text-align: center;
  padding: .625rem 1rem; border-radius: .75rem; border: 1px solid var(--border);
  background: var(--bg-secondary); font-size: .8rem; font-weight: 500;
  color: var(--text-secondary); transition: all .2s;
}
.sp-checkbox input:checked + .sp-checkbox-inner { border-color: var(--green); background: rgba(0,204,0,0.08); color: var(--green); }

/* Success CTA */
.sp-success-cta { text-align: center; padding: 4rem 2rem; max-width: 36rem; margin: 0 auto; }
.sp-success-icon { color: var(--green); margin: 0 auto 1.5rem; display: flex; justify-content: center; }
.sp-success-cta h3 { font-size: 1.75rem; font-weight: 700; color: var(--text-primary); margin-bottom: 1rem; }
.sp-success-cta p { color: var(--text-secondary); line-height: 1.7; margin-bottom: 2rem; }
.sp-success-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* Packages page extras */
.sp-pkg-popular { border: 2px solid var(--green); position: relative; }
.sp-pkg-popular-badge {
  position: absolute; top: -1rem; left: 50%; transform: translateX(-50%);
  background: var(--green); color: #000; font-size: .75rem; font-weight: 700;
  padding: .2rem .875rem; border-radius: 9999px; white-space: nowrap;
  display: flex; align-items: center; gap: .25rem;
}
.sp-pkg-cat { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--green); margin-bottom: .5rem; }
.sp-pkg-actions { display: flex; gap: .75rem; margin-top: auto; }

/* White label page */
.wl-hero { padding: 9rem 0 5rem; background: var(--bg-primary); }
.wl-hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.wl-trust-row { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.wl-trust-item { display: flex; align-items: center; gap: .4rem; font-size: .8rem; color: var(--text-muted); }
.wl-stat-stack { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.wl-stat-card { padding: 1.5rem; border-radius: 1rem; text-align: center; }
.wl-stat-val { display: block; font-size: 2rem; font-weight: 900; color: var(--green); font-family: var(--font-heading); }
.wl-stat-lbl { font-size: .75rem; color: var(--text-muted); margin-top: .25rem; display: block; }
.wl-models-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.wl-model-card { padding: 2rem; border-radius: 1rem; }
.wl-faq-item { border-bottom: 1px solid var(--border); padding: 1.5rem 0; }
.wl-faq-q { font-size: 1rem; font-weight: 700; color: var(--text-primary); margin-bottom: .5rem; }
.wl-faq-a { font-size: .875rem; color: var(--text-muted); line-height: 1.7; }
@media(max-width:1024px){ .wl-hero-inner { grid-template-columns: 1fr; } .wl-models-grid { grid-template-columns: 1fr; } }
@media(max-width:640px){ .wl-stat-stack { grid-template-columns: 1fr 1fr; } }

/* ===== SUB-SERVICES ===== */
.service-breadcrumb { padding: 5.5rem 0 0; background: var(--bg-primary); }
.service-breadcrumb .container { display: flex; align-items: center; gap: .5rem; font-size: .8rem; color: var(--text-muted); flex-wrap: wrap; }
.service-breadcrumb a { color: var(--text-muted); transition: color .2s; }
.service-breadcrumb a:hover { color: var(--green); }
.service-breadcrumb span[aria-current] { color: var(--text-primary); font-weight: 500; }
.sub-services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr)); gap: 1.25rem; }
.sub-service-card { display: flex; flex-direction: column; align-items: flex-start; gap: .75rem; padding: 1.5rem; border-radius: 1rem; border: 1px solid var(--border); background: var(--bg-primary); text-decoration: none; transition: border-color .2s, transform .2s, box-shadow .2s; }
.sub-service-card:hover { border-color: var(--green); transform: translateY(-4px); box-shadow: 0 6px 24px rgba(0,204,0,0.1); }
.sub-service-icon { color: var(--green); }
.sub-service-card h3 { font-size: .9rem; font-weight: 700; color: var(--text-primary); }
.sub-service-card p { font-size: .78rem; color: var(--text-muted); line-height: 1.5; flex: 1; }
.sub-service-link { color: var(--green); margin-top: auto; }

/* Tech tag SVG icon */
.tech-tag-svg { display: flex; align-items: center; width: 20px; height: 20px; flex-shrink: 0; }
.tech-tag-svg svg { width: 20px; height: 20px; }

/* ===== START PROJECT PAGE (new) ===== */
.sp-hero { padding: 8rem 0 3rem; background: var(--bg-primary); }
.sp-hero-trust { display: flex; flex-wrap: wrap; justify-content: center; gap: 1.25rem; margin-top: 1.5rem; }
.sp-hero-trust span { display: flex; align-items: center; gap: .35rem; font-size: .8rem; color: var(--text-muted); }
.sp-hero-trust span svg { color: var(--green); flex-shrink: 0; }

.sp-form-section { padding: 2rem 0 6rem; background: var(--bg-primary); }
.sp-form-wrap { max-width: 54rem; margin: 0 auto; background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 1.5rem; overflow: hidden; }

/* Progress bar */
.sp-progress { height: 3px; background: var(--border); }
.sp-progress-bar { height: 100%; background: var(--green); transition: width .4s cubic-bezier(.4,0,.2,1); }

/* Step tabs */
.sp-steps { display: flex; border-bottom: 1px solid var(--border); }
.sp-step { flex: 1; display: flex; align-items: center; justify-content: center; gap: .5rem; padding: 1rem .5rem; font-size: .8rem; font-weight: 600; color: var(--text-muted); transition: color .2s; cursor: default; }
.sp-step-num { display: flex; align-items: center; justify-content: center; color: var(--text-muted); transition: color .2s; }
.sp-step-active { color: var(--green); border-bottom: 2px solid var(--green); margin-bottom: -1px; }
.sp-step-active .sp-step-num { color: var(--green); }
.sp-step-done { color: var(--text-secondary); }
.sp-step-done .sp-step-num { color: var(--green); }
@media(max-width:480px){ .sp-step-label { display: none; } .sp-step { padding: .875rem .25rem; } }

/* Form padding */
.sp-form { padding: 2.5rem; }
@media(max-width:640px){ .sp-form { padding: 1.5rem; } }

/* Panel */
.sp-panel { display: none; }
.sp-panel-active { display: block; }
.sp-panel-head { margin-bottom: 2rem; }
.sp-panel-step { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .15em; color: var(--green); }
.sp-panel-head h2 { font-size: 1.5rem; font-weight: 700; color: var(--text-primary); margin: .35rem 0 .5rem; }
.sp-panel-head p { font-size: .875rem; color: var(--text-muted); }

/* Service cards */
.sp-service-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(9rem, 1fr)); gap: .75rem; }
.sp-service-card { cursor: pointer; }
.sp-service-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.sp-service-inner { display: flex; flex-direction: column; align-items: center; gap: .5rem; padding: 1.25rem .75rem; border-radius: .875rem; border: 1px solid var(--border); background: var(--bg-primary); text-align: center; transition: all .2s; position: relative; }
.sp-service-icon { color: var(--text-muted); transition: color .2s; }
.sp-service-title { font-size: .8rem; font-weight: 600; color: var(--text-secondary); transition: color .2s; }
.sp-service-link { font-size: .65rem; color: var(--text-muted); text-decoration: underline; display: none; }
.sp-service-card input:checked + .sp-service-inner { border-color: var(--green); background: rgba(0,204,0,0.06); }
.sp-service-card input:checked + .sp-service-inner .sp-service-icon { color: var(--green); }
.sp-service-card input:checked + .sp-service-inner .sp-service-title { color: var(--green); }
.sp-service-card input:checked + .sp-service-inner .sp-service-link { display: block; }
.sp-service-inner:hover { border-color: rgba(0,204,0,0.35); }

/* Sub-services */
.sp-sub-wrap { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.sp-sub-title { font-size: .9rem; font-weight: 700; color: var(--text-primary); margin-bottom: 1rem; }
.sp-sub-title span { font-weight: 400; color: var(--text-muted); margin-left: .5rem; }

/* Project type cards */
.sp-type-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr)); gap: .75rem; }
.sp-type-card { cursor: pointer; }
.sp-type-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.sp-type-inner { display: flex; flex-direction: column; gap: .25rem; padding: 1rem 1.25rem; border-radius: .875rem; border: 1px solid var(--border); background: var(--bg-primary); transition: all .2s; }
.sp-type-inner strong { font-size: .875rem; color: var(--text-primary); }
.sp-type-inner span { font-size: .75rem; color: var(--text-muted); }
.sp-type-card input:checked + .sp-type-inner { border-color: var(--green); background: rgba(0,204,0,0.06); }
.sp-type-card input:checked + .sp-type-inner strong { color: var(--green); }
.sp-type-inner:hover { border-color: rgba(0,204,0,0.35); }

/* Budget cards */
.sp-budget-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; }
.sp-budget-card { cursor: pointer; }
.sp-budget-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.sp-budget-inner { display: flex; flex-direction: column; gap: .2rem; padding: 1rem 1.25rem; border-radius: .875rem; border: 1px solid var(--border); background: var(--bg-primary); transition: all .2s; }
.sp-budget-inner strong { font-size: .875rem; font-weight: 700; color: var(--text-primary); }
.sp-budget-inner span { font-size: .75rem; color: var(--text-muted); }
.sp-budget-card input:checked + .sp-budget-inner { border-color: var(--green); background: rgba(0,204,0,0.06); }
.sp-budget-card input:checked + .sp-budget-inner strong { color: var(--green); }
.sp-budget-inner:hover { border-color: rgba(0,204,0,0.35); }
@media(max-width:640px){ .sp-budget-grid { grid-template-columns: 1fr 1fr; } }

/* Contact method */
.sp-contact-grid { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: .5rem; }

/* Form nav */
.sp-form-nav { display: flex; align-items: center; justify-content: space-between; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.sp-nav-right { display: flex; gap: .75rem; }
.sp-btn-back, .sp-btn-next { display: flex; align-items: center; gap: .4rem; }
.sp-form-msg { margin-top: 1rem; font-size: .875rem; text-align: center; min-height: 1.25rem; }
.sp-form-msg.error { color: #EF4444; }

/* Success state */
.sp-success { padding: 4rem 2.5rem; text-align: center; }
.sp-success-check { color: var(--green); margin: 0 auto 1.5rem; display: flex; justify-content: center; }
.sp-success h2 { font-size: 1.75rem; font-weight: 700; color: var(--text-primary); margin-bottom: 1rem; }
.sp-success p { color: var(--text-secondary); line-height: 1.7; margin-bottom: 2rem; max-width: 32rem; margin-left: auto; margin-right: auto; }
.sp-success-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ===== SERVICE FLAG BADGES ===== */
.svc-flag {
  display: inline-block; font-size: .65rem; font-weight: 700;
  padding: .2rem .6rem; border-radius: 9999px; margin-bottom: .75rem;
}
.svc-flag--trending  { background: rgba(220,38,38,0.12);  color: #DC2626; }
.svc-flag--demand    { background: rgba(217,119,6,0.12);  color: #D97706; }
.svc-flag--emerging  { background: rgba(124,58,237,0.12); color: #7C3AED; }

/* ===== SERVICES LIST PAGE — HIERARCHY ===== */
.svc-section-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 2rem; margin-bottom: 2rem; flex-wrap: wrap;
}
.svc-section-meta { display: flex; align-items: flex-start; gap: 1.25rem; flex: 1; }
.svc-section-title { font-size: clamp(1.5rem,3vw,2rem); font-weight: 700; color: var(--text-primary); margin: .25rem 0 .5rem; }
.svc-section-desc { font-size: .9rem; color: var(--text-muted); line-height: 1.6; max-width: 40rem; }
.svc-section-btn { white-space: nowrap; flex-shrink: 0; display: inline-flex; align-items: center; gap: .4rem; }

/* Children grid */
.svc-children-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr)); gap: .75rem;
}
.svc-child-card {
  display: flex; align-items: center; gap: .875rem;
  padding: .875rem 1rem; border-radius: .75rem;
  border: 1px solid var(--border); background: var(--bg-primary);
  text-decoration: none; transition: border-color .2s, transform .15s, box-shadow .2s;
}
.svc-child-card:hover { border-color: var(--green); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,204,0,0.08); }
.svc-child-icon { color: var(--green); flex-shrink: 0; }
.svc-child-body { flex: 1; min-width: 0; }
.svc-child-body strong { display: block; font-size: .85rem; font-weight: 600; color: var(--text-primary); }
.svc-child-body span { display: block; font-size: .72rem; color: var(--text-muted); margin-top: .1rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.svc-child-flag { font-size: .65rem; font-style: normal; color: var(--text-muted); margin-top: .15rem; display: block; }
.svc-child-arrow { color: var(--text-muted); flex-shrink: 0; transition: color .2s; }
.svc-child-card:hover .svc-child-arrow { color: var(--green); }

@media(max-width:640px){
  .svc-section-head { flex-direction: column; }
  .svc-section-btn { width: 100%; justify-content: center; }
  .svc-children-grid { grid-template-columns: 1fr; }
}

/* ===== SERVICE OFFER GRID (merged sub-services + cards) ===== */
.svc-offer-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr)); gap: 1rem; }
.svc-offer-card {
  display: flex; align-items: flex-start; gap: 1rem;
  padding: 1.25rem; border-radius: 1rem; border: 1px solid var(--border);
  background: var(--bg-primary); text-decoration: none;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.svc-offer-card:hover { border-color: var(--green); transform: translateY(-3px); box-shadow: 0 6px 24px rgba(0,204,0,0.1); }
.svc-offer-icon { color: var(--green); flex-shrink: 0; margin-top: .1rem; }
.svc-offer-body { flex: 1; min-width: 0; }
.svc-offer-head { display: flex; align-items: center; gap: .4rem; margin-bottom: .35rem; flex-wrap: wrap; }
.svc-offer-head h3 { font-size: .9rem; font-weight: 700; color: var(--text-primary); margin: 0; }
.svc-offer-body p { font-size: .78rem; color: var(--text-muted); line-height: 1.5; margin-bottom: .5rem; }
.svc-offer-features { list-style: none; display: flex; flex-direction: column; gap: .2rem; }
.svc-offer-features li { display: flex; align-items: center; gap: .3rem; font-size: .72rem; color: var(--text-secondary); }
.svc-offer-features li svg { color: var(--green); flex-shrink: 0; }
.svc-offer-arrow { color: var(--text-muted); flex-shrink: 0; margin-top: .1rem; transition: color .2s; }
.svc-offer-card:hover .svc-offer-arrow { color: var(--green); }
@media(max-width:640px){ .svc-offer-grid { grid-template-columns: 1fr; } }

/* ===== HIRE A TEAM PAGE ===== */
.ht-hero { padding: 9rem 0 5rem; background: var(--bg-primary); }
.ht-hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.ht-hero-desc { font-size: 1.125rem; color: var(--text-secondary); line-height: 1.7; margin: 1.5rem 0 2rem; }
.ht-hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.ht-hero-trust { display: flex; flex-wrap: wrap; gap: 1rem; }
.ht-hero-trust span { display: flex; align-items: center; gap: .35rem; font-size: .8rem; color: var(--text-muted); }
.ht-hero-trust span svg { color: var(--green); flex-shrink: 0; }
.ht-hero-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.ht-stat { padding: 1.5rem; border-radius: 1rem; text-align: center; }
.ht-stat-val { display: block; font-size: 2rem; font-weight: 900; color: var(--green); font-family: var(--font-heading); }
.ht-stat-lbl { font-size: .75rem; color: var(--text-muted); margin-top: .25rem; display: block; }

/* Engagement models */
.ht-models-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.ht-model-card { padding: 2rem; border-radius: 1rem; display: flex; flex-direction: column; gap: .75rem; position: relative; }
.ht-model-popular { border: 2px solid var(--green) !important; }
.ht-model-badge { position: absolute; top: -1rem; left: 50%; transform: translateX(-50%); background: var(--green); color: #000; font-size: .7rem; font-weight: 700; padding: .2rem .875rem; border-radius: 9999px; white-space: nowrap; display: flex; align-items: center; gap: .25rem; }
.ht-model-card h3 { font-size: 1.25rem; font-weight: 700; color: var(--text-primary); }
.ht-model-price { font-size: 1.5rem; font-weight: 900; color: var(--green); }
.ht-model-card p { font-size: .875rem; color: var(--text-muted); line-height: 1.6; }
.ht-model-features { list-style: none; display: flex; flex-direction: column; gap: .4rem; flex: 1; }
.ht-model-features li { display: flex; align-items: center; gap: .4rem; font-size: .8rem; color: var(--text-secondary); }
.ht-model-features li svg { color: var(--green); flex-shrink: 0; }

/* Skills */
.ht-skill-group { margin-bottom: 1.5rem; }
.ht-skill-label { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-muted); margin-bottom: .75rem; }
.ht-skill-tags { display: flex; flex-wrap: wrap; gap: .5rem; }

/* Roles */
.ht-roles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(14rem,1fr)); gap: 1rem; }
.ht-role-card { padding: 1.25rem; border-radius: .875rem; display: flex; flex-direction: column; gap: .35rem; }
.ht-role-icon { color: var(--green); margin-bottom: .25rem; }
.ht-role-card strong { font-size: .9rem; font-weight: 700; color: var(--text-primary); }
.ht-role-card span { font-size: .75rem; color: var(--text-muted); }

@media(max-width:1024px){ .ht-hero-inner { grid-template-columns: 1fr; } .ht-models-grid { grid-template-columns: 1fr; max-width: 28rem; margin: 0 auto; } }
@media(max-width:640px){ .ht-hero-stats { grid-template-columns: 1fr 1fr; } }

/* ===== WHITE LABEL SERVICES GRID ===== */
.wl-services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(16rem,1fr)); gap: 1.25rem; }
.wl-svc-card { padding: 1.5rem; border-radius: 1rem; }
.wl-svc-icon { color: var(--green); margin-bottom: .875rem; }
.wl-svc-card h3 { font-size: .95rem; font-weight: 700; color: var(--text-primary); margin-bottom: .75rem; }
.wl-svc-card ul { list-style: none; display: flex; flex-direction: column; gap: .3rem; }
.wl-svc-card li { display: flex; align-items: center; gap: .35rem; font-size: .78rem; color: var(--text-secondary); }
.wl-svc-card li svg { color: var(--green); flex-shrink: 0; }

/* ===== HIRE & PARTNER PAGE ===== */
.partner-hero { padding: 9rem 0 5rem; background: var(--bg-primary); }
.partner-hero-inner { display: grid; grid-template-columns: 1.1fr 1fr; gap: 4rem; align-items: center; }
.partner-hero-desc { font-size: 1.125rem; color: var(--text-secondary); line-height: 1.7; margin: 1.5rem 0 2rem; }
.partner-hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.partner-trust { display: flex; flex-wrap: wrap; gap: .875rem; }
.partner-trust span { display: flex; align-items: center; gap: .35rem; font-size: .78rem; color: var(--text-muted); }
.partner-trust span svg { color: var(--green); flex-shrink: 0; }
.partner-hero-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: .875rem; }
.partner-stat { padding: 1.25rem; border-radius: .875rem; text-align: center; }
.partner-stat-val { display: block; font-size: 1.75rem; font-weight: 900; color: var(--green); font-family: var(--font-heading); }
.partner-stat-lbl { font-size: .7rem; color: var(--text-muted); margin-top: .2rem; display: block; }

/* Who grid */
.partner-who-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.partner-who-card { padding: 1.75rem; border-radius: 1rem; }
.partner-who-icon { color: var(--green); margin-bottom: 1rem; }
.partner-who-card h3 { font-size: 1rem; font-weight: 700; color: var(--text-primary); margin-bottom: .5rem; }
.partner-who-card p { font-size: .8rem; color: var(--text-muted); line-height: 1.6; }

/* Models grid */
.partner-models-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.25rem; }
.partner-model-card { padding: 1.75rem; border-radius: 1rem; display: flex; flex-direction: column; gap: .75rem; position: relative; }
.partner-model-popular { border: 2px solid var(--green) !important; }
.partner-model-badge { position: absolute; top: -1rem; left: 50%; transform: translateX(-50%); background: var(--green); color: #000; font-size: .7rem; font-weight: 700; padding: .2rem .875rem; border-radius: 9999px; white-space: nowrap; display: flex; align-items: center; gap: .25rem; }
.partner-model-top { display: flex; align-items: center; gap: .875rem; }
.partner-model-tag { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--green); display: block; margin-bottom: .2rem; }
.partner-model-card h3 { font-size: 1rem; font-weight: 700; color: var(--text-primary); margin: 0; }
.partner-model-price { font-size: 1.25rem; font-weight: 900; color: var(--green); }
.partner-model-card > p { font-size: .8rem; color: var(--text-muted); line-height: 1.6; }
.partner-model-features { list-style: none; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.partner-model-features li { display: flex; align-items: center; gap: .4rem; font-size: .78rem; color: var(--text-secondary); }
.partner-model-features li svg { color: var(--green); flex-shrink: 0; }

@media(max-width:1280px){ .partner-models-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:1024px){ .partner-hero-inner { grid-template-columns: 1fr; } .partner-who-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px){ .partner-hero-stats { grid-template-columns: repeat(3,1fr); } .partner-who-grid { grid-template-columns: 1fr; } .partner-models-grid { grid-template-columns: 1fr; } }

/* ===== GENERIC PAGE (page.php) ===== */
.page-hero-desc {
  font-size: 1.125rem; color: var(--text-secondary);
  max-width: 48rem; margin-top: 1rem; line-height: 1.7;
}

.prose-content {
  max-width: 52rem;
  margin: 0 auto;
  color: var(--text-secondary);
  font-size: 1rem;
  line-height: 1.8;
}

.prose-content h1,
.prose-content h2,
.prose-content h3,
.prose-content h4,
.prose-content h5,
.prose-content h6 {
  color: var(--text-primary);
  font-weight: 700;
  line-height: 1.25;
  margin: 2rem 0 .75rem;
}
.prose-content h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); }
.prose-content h2 { font-size: clamp(1.4rem, 3vw, 2rem); }
.prose-content h3 { font-size: 1.25rem; }
.prose-content h4 { font-size: 1.1rem; }

.prose-content p  { margin-bottom: 1.25rem; }

.prose-content a {
  color: var(--green);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.prose-content a:hover { color: var(--green-hover); }

.prose-content ul,
.prose-content ol {
  padding-left: 1.5rem;
  margin-bottom: 1.25rem;
}
.prose-content ul { list-style: disc; }
.prose-content ol { list-style: decimal; }
.prose-content li { margin-bottom: .4rem; }

.prose-content blockquote {
  border-left: 3px solid var(--green);
  padding: .75rem 1.25rem;
  margin: 1.5rem 0;
  background: var(--bg-secondary);
  border-radius: 0 .5rem .5rem 0;
  color: var(--text-secondary);
  font-style: italic;
}

.prose-content hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 2.5rem 0;
}

.prose-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1.5rem;
  font-size: .9rem;
}
.prose-content th,
.prose-content td {
  padding: .65rem 1rem;
  border: 1px solid var(--border);
  text-align: left;
}
.prose-content th {
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-weight: 600;
}

.prose-content img {
  max-width: 100%;
  height: auto;
  border-radius: .5rem;
  margin: 1.5rem 0;
}

.prose-content code {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: .25rem;
  padding: .15em .4em;
  font-size: .875em;
  color: var(--green);
}

.prose-content pre {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: .5rem;
  padding: 1.25rem;
  overflow-x: auto;
  margin-bottom: 1.5rem;
}
.prose-content pre code {
  background: none;
  border: none;
  padding: 0;
  color: var(--text-primary);
}

/* ═══════════════════════════════════════════════════════════════
   SERVICE PAGE — COMPLETE STYLES (10-section template)
═══════════════════════════════════════════════════════════════ */

/* ── Hero trust signals ── */
.hero-trust-signals {
  display: flex; flex-wrap: wrap; gap: .75rem 1.5rem;
  margin-top: 2rem;
}
.trust-signal {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .8rem; font-weight: 600; color: var(--text-secondary);
}
.trust-signal svg { color: var(--green); flex-shrink: 0; }

/* ── Tech Icons Grid (Section 4) ── */
.tech-section { overflow: hidden; }
.tech-tags-icons {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 1.5rem;
  list-style: none; padding: 0; margin: 0;
}
.tech-icon-item {
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
  cursor: default;
}
.tech-icon-badge {
  width: 64px; height: 64px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.tech-icon-item:hover .tech-icon-badge {
  border-color: var(--green);
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,204,0,.15);
}
.tech-icon-svg { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; }
.tech-icon-svg svg { width: 100%; height: 100%; display: block; border-radius: 13px; }
.tech-icon-img { width: 40px; height: 40px; object-fit: contain; border-radius: 6px; }
.tech-icon-fallback {
  font-size: .75rem; font-weight: 800; color: var(--green);
  text-transform: uppercase; letter-spacing: .03em;
}
.tech-icon-name {
  font-size: .7rem; font-weight: 600; color: var(--text-secondary);
  text-align: center; line-height: 1.3;
  max-width: 80px; word-break: break-word;
}
@media(max-width:640px){
  .tech-tags-icons { grid-template-columns: repeat(auto-fill, minmax(72px, 1fr)); gap: 1rem; }
  .tech-icon-badge { width: 54px; height: 54px; border-radius: 12px; }
}

/* ── Audience / Who This Is For (Section 5) ── */
.audience-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.audience-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1.25rem;
  padding: 2rem 1.75rem;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.audience-card:hover {
  border-color: var(--green);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,204,0,.1);
}
.audience-icon {
  width: 52px; height: 52px; border-radius: 12px;
  background: rgba(0,204,0,.08); border: 1px solid rgba(0,204,0,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--green); margin-bottom: 1.25rem;
}
.audience-card h3 {
  font-size: 1.05rem; font-weight: 700; color: var(--text-primary);
  margin-bottom: .6rem;
}
.audience-card p {
  font-size: .875rem; color: var(--text-secondary); line-height: 1.7; margin: 0;
}
@media(max-width:1024px){ .audience-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:640px){ .audience-grid { grid-template-columns: 1fr; } }

/* ── Why Choose Us (Section 6) ── */
.why-us-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 3rem;
}
.why-us-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1.25rem;
  padding: 1.75rem 1.5rem;
  transition: border-color .2s, transform .2s;
}
.why-us-card:hover { border-color: var(--green); transform: translateY(-3px); }
.why-us-icon {
  width: 48px; height: 48px; border-radius: 10px;
  background: rgba(0,204,0,.08); border: 1px solid rgba(0,204,0,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--green); margin-bottom: 1rem;
}
.why-us-card h3 { font-size: .95rem; font-weight: 700; color: var(--text-primary); margin-bottom: .5rem; }
.why-us-card p  { font-size: .825rem; color: var(--text-secondary); line-height: 1.65; margin: 0; }

/* Comparison table */
.comparison-wrap { border-radius: 1rem; overflow: hidden; border: 1px solid var(--border); }
.comparison-table {
  width: 100%; border-collapse: collapse;
  font-size: .875rem;
}
.comparison-table thead tr {
  background: var(--bg-secondary);
}
.comparison-table th {
  padding: .875rem 1.25rem; text-align: center;
  font-size: .75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-secondary);
  border-bottom: 1px solid var(--border);
}
.comparison-table th:first-child { text-align: left; }
.comparison-table th.col-us { color: var(--green); }
.comparison-table td {
  padding: .875rem 1.25rem; text-align: center;
  border-bottom: 1px solid var(--border);
  color: var(--text-secondary); font-size: .875rem;
}
.comparison-table td:first-child { text-align: left; color: var(--text-primary); font-weight: 500; }
.comparison-table td.col-us { background: rgba(0,204,0,.04); }
.comparison-table tbody tr:last-child td { border-bottom: none; }
.comparison-table tbody tr:hover td { background: var(--glass-bg); }
.cmp-yes { color: var(--green); font-size: 1.1rem; font-weight: 700; }
.cmp-no  { color: var(--text-muted); font-size: 1.1rem; }

@media(max-width:1024px){ .why-us-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:640px){
  .why-us-grid { grid-template-columns: 1fr; }
  .comparison-table { font-size: .75rem; }
  .comparison-table th, .comparison-table td { padding: .625rem .75rem; }
}

/* ── Pricing Transparency (Section 7) ── */
.pricing-tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 2rem;
}
.pricing-tier-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1.25rem;
  padding: 2rem 1.75rem; text-align: center;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  position: relative; overflow: hidden;
}
.pricing-tier-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 3px; background: linear-gradient(90deg, var(--green), transparent);
  opacity: 0; transition: opacity .2s;
}
.pricing-tier-card:hover {
  border-color: var(--green);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,204,0,.12);
}
.pricing-tier-card:hover::before { opacity: 1; }
.pricing-tier-label {
  font-size: .75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--green); margin-bottom: .75rem;
}
.pricing-tier-range {
  font-size: 1.5rem; font-weight: 800; color: var(--text-primary);
  margin-bottom: .75rem; line-height: 1.2;
}
.pricing-tier-note {
  font-size: .8rem; color: var(--text-secondary); line-height: 1.6; margin: 0;
}
.pricing-models-label {
  font-size: .8rem; color: var(--text-muted); margin-bottom: .75rem;
  text-transform: uppercase; letter-spacing: .06em; font-weight: 600;
}
.pricing-models-list {
  display: flex; flex-wrap: wrap; justify-content: center; gap: .75rem;
}
.pricing-model-badge {
  display: inline-flex; align-items: center;
  padding: .5rem 1.25rem; border-radius: 9999px;
  border: 1px solid var(--border); background: var(--glass-bg);
  font-size: .8rem; font-weight: 600; color: var(--text-primary);
  backdrop-filter: blur(12px);
}
@media(max-width:1024px){ .pricing-tiers { grid-template-columns: 1fr 1fr; } }
@media(max-width:640px){ .pricing-tiers { grid-template-columns: 1fr; } }

/* ── FAQ Accordion (Section 8) ── */
.faq-list {
  max-width: 52rem; margin: 0 auto;
  display: flex; flex-direction: column; gap: .75rem;
}
.faq-item {
  border: 1px solid var(--border); border-radius: 1rem;
  background: var(--glass-bg); backdrop-filter: blur(12px);
  overflow: hidden;
  transition: border-color .2s;
}
.faq-item:has(.faq-question[aria-expanded="true"]) { border-color: var(--green); }
.faq-question {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 1.25rem 1.5rem;
  background: none; border: none; cursor: pointer; text-align: left;
  font-size: .95rem; font-weight: 600; color: var(--text-primary);
  line-height: 1.5;
  transition: color .2s;
}
.faq-question:hover { color: var(--green); }
.faq-question[aria-expanded="true"] { color: var(--green); }
.faq-chevron {
  flex-shrink: 0; color: var(--text-muted);
  transition: transform .25s ease, color .2s;
}
.faq-question[aria-expanded="true"] .faq-chevron {
  transform: rotate(180deg); color: var(--green);
}
.faq-answer {
  padding: 0 1.5rem 1.25rem;
  border-top: 1px solid var(--border);
}
.faq-answer[hidden] { display: none; }
.faq-answer p {
  font-size: .875rem; color: var(--text-secondary);
  line-height: 1.75; margin: 1rem 0 0;
}

/* ── Related Services (Section 9) ── */
.related-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.related-service-card {
  display: flex; align-items: center; gap: 1rem;
  padding: 1.25rem 1.5rem; border-radius: 1rem;
  border: 1px solid var(--border); background: var(--bg-primary);
  text-decoration: none;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.related-service-card:hover {
  border-color: var(--green);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,204,0,.1);
}
.related-service-icon {
  width: 44px; height: 44px; border-radius: 10px; flex-shrink: 0;
  background: rgba(0,204,0,.08); border: 1px solid rgba(0,204,0,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--green);
}
.related-service-body { flex: 1; min-width: 0; }
.related-service-body h3 {
  font-size: .9rem; font-weight: 700; color: var(--text-primary);
  margin: 0 0 .25rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.related-service-body p {
  font-size: .775rem; color: var(--text-secondary); margin: 0;
  line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.related-service-arrow { color: var(--text-muted); flex-shrink: 0; transition: color .2s, transform .2s; }
.related-service-card:hover .related-service-arrow { color: var(--green); transform: translateX(3px); }

@media(max-width:1024px){ .related-services-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:640px){ .related-services-grid { grid-template-columns: 1fr; } }

/* ── WooCommerce Package Cards ── */
.sp-pkg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.sp-pkg-card {
  backdrop-filter: blur(20px); background: var(--glass-bg);
  border: 1px solid var(--border); border-radius: 1.25rem;
  padding: 2rem 1.75rem; position: relative;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  display: flex; flex-direction: column; gap: 1rem;
}
.sp-pkg-card:hover {
  border-color: var(--green);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,204,0,.12);
}
.sp-pkg-popular {
  border-color: var(--green);
  box-shadow: 0 0 0 1px var(--green), 0 12px 32px rgba(0,204,0,.15);
}
.sp-pkg-popular-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--green);
  background: rgba(0,204,0,.1); border: 1px solid rgba(0,204,0,.3);
  border-radius: 9999px; padding: .3rem .75rem;
  width: fit-content;
}
.sp-pkg-card h3 { font-size: 1.1rem; font-weight: 700; color: var(--text-primary); margin: 0; }
.sp-pkg-price { font-size: 1.75rem; font-weight: 800; color: var(--green); }
.sp-pkg-features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.sp-pkg-features li { display: flex; align-items: flex-start; gap: .5rem; font-size: .85rem; color: var(--text-secondary); line-height: 1.5; }
.sp-pkg-features li svg { color: var(--green); flex-shrink: 0; margin-top: .1rem; }
.sp-pkg-actions { display: flex; gap: .75rem; margin-top: auto; }
@media(max-width:1024px){ .sp-pkg-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:640px){ .sp-pkg-grid { grid-template-columns: 1fr; } }

/* ── Service Flags ── */
.svc-flag { font-size: .75rem; line-height: 1; }
.svc-flag--trending, .svc-flag--demand { display: inline-flex; }
