
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --brand: #3b82f6;
  --brand-light: #60a5fa;
  --primary: #1B2A4A;
  --accent: #fd4f4e;
  --text: #1a1a2e;
  --text-muted: #6b7280;
  --bg: #ffffff;
  --bg-muted: #f9fafb;
  --border: #e5e7eb;
  --card: #ffffff;
}


.max-w-7xl { max-width: 80rem; margin: 0 auto; }

/* ===== ANIMATIONS ===== */
.fade-in { opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; }
.fade-in.visible { opacity: 1; transform: translateY(0); }

/* ===== LUCIDE ICONS ===== */
.lucide-icon { display: inline-block; vertical-align: middle; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ===== HERO ===== */
.hero { position: relative; min-height: 92vh; display: flex; align-items: center; overflow: hidden; padding-top:5rem; }
.hero-bg { position: absolute; inset: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(10,22,40,0.95), rgba(10,22,40,0.85), rgba(10,22,40,0.70)); }
.hero .container { position: relative; z-index: 10; padding: 6rem 1rem; }
.hero-grid { display: grid; grid-template-columns: 7fr 5fr; gap: 3rem; align-items: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.625rem 1.25rem; border-radius: 9999px; margin-bottom: 1.5rem; border: 1px solid; font-size: 0.875rem; font-weight: 600; }
.hero-badge svg { width: 1rem; height: 1rem; }
.hero h1 { font-size: 3.5rem; font-weight: 800; color: white; line-height: 1.1; margin-bottom: 1.5rem; }
.hero-desc { font-size: 1.25rem; color: rgba(255,255,255,0.7); margin-bottom: 2rem; line-height: 1.7; max-width: 40rem; }
.hero-buttons { display: flex; gap: 1rem; margin-bottom: 3rem; flex-wrap: wrap; }
.btn-brand { display: inline-flex; align-items: center; gap: 0.5rem; background: var(--brand); color: white; font-weight: 600; font-size: 1.125rem; padding: 0.875rem 2rem; border-radius: 0.75rem; border: none; cursor: pointer; text-decoration: none; box-shadow: 0 10px 25px rgba(0,0,0,0.2); transition: filter 0.3s; }
.btn-brand:hover { filter: brightness(1.1); }
.btn-brand svg { width: 1.25rem; height: 1.25rem; }
.btn-outline { display: inline-flex; align-items: center; gap: 0.5rem; background: rgba(255,255,255,0.05); color: white; font-weight: 600; font-size: 1.125rem; padding: 0.875rem 2rem; border-radius: 0.75rem; border: 2px solid rgba(255,255,255,0.2); cursor: pointer; text-decoration: none; backdrop-filter: blur(4px); transition: background 0.3s; }
.btn-outline:hover { background: rgba(255,255,255,0.1); }
.hero-stats { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.hero-stat { text-align: center; }
.hero-stat-value { font-size: 1.5rem; font-weight: 700; color: var(--brand); }
.hero-stat-label { font-size: 0.75rem; color: rgba(255,255,255,0.5); margin-top: 0.25rem; }
.hero-cards { display: flex; flex-direction: column; gap: 1rem; }
.hero-card { display: flex; align-items: center; gap: 1rem; background: rgba(255,255,255,0.05); backdrop-filter: blur(8px); border-radius: 0.75rem; padding: 1rem 1.5rem; border: 1px solid rgba(255,255,255,0.1); transition: border-color 0.3s; }
.hero-card:hover { border-color: rgba(255,255,255,0.3); }
.hero-card-icon { width: 3rem; height: 3rem; border-radius: 0.5rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.hero-card-icon svg { width: 1.5rem; height: 1.5rem; color: var(--brand); }
.hero-card-label { color: white; font-weight: 600; }
.hero-card-desc { color: rgba(255,255,255,0.5); font-size: 0.875rem; }
.hero-scroll { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); text-align: center; color: rgba(255,255,255,0.4); font-size: 0.875rem; }
.hero-scroll svg { width: 1.25rem; height: 1.25rem; animation: bounce 1.5s infinite; }
@keyframes bounce { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(8px); } }

/* ===== SECTION COMMON ===== */
.section { padding: 6rem 0; }
.section-muted { background: var(--bg-muted); }
.section-dark { background: #0a1628; color: white; position: relative; overflow: hidden; }
.section-dark .dot-pattern { position: absolute; inset: 0; opacity: 0.05; background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.15) 1px, transparent 0); background-size: 32px 32px; }
.section-header { text-align: center; margin-bottom: 4rem; }
.section-badge { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.875rem; font-weight: 600; padding: 0.5rem 1rem; border-radius: 9999px; margin-bottom: 1rem; }
.section-badge-brand { background: color-mix(in srgb, var(--brand) 10%, transparent); color: var(--brand); }
.section-badge-accent { background: rgba(253,79,78,0.1); color: var(--accent); }
.section-badge-dark { border: 1px solid; }
.section-title { font-size: 2.5rem; font-weight: 700; margin-bottom: 1rem; }
.section-title .brand { color: var(--brand); }
.section-title .accent { color: var(--accent); }
.section-subtitle { font-size: 1.125rem; color: var(--text-muted); max-width: 42rem; margin: 0 auto; }
.section-dark .section-title { color: white; }
.section-dark .section-subtitle { color: rgba(255,255,255,0.5); }

/* ===== BENEFITS ===== */
.benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.benefit-card { background: var(--card); border-radius: 1rem; padding: 2rem; border: 1px solid var(--border); transition: all 0.3s; position: relative; overflow: hidden; }
.benefit-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.08); }
.benefit-card-corner { position: absolute; top: 0; right: 0; width: 6rem; height: 6rem; border-bottom-left-radius: 100%; }
.benefit-top { display: flex; align-items: start; justify-content: space-between; margin-bottom: 1rem; }
.benefit-icon { width: 3.5rem; height: 3.5rem; border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; transition: transform 0.3s; }
.benefit-card:hover .benefit-icon { transform: scale(1.1); }
.benefit-icon svg { width: 1.75rem; height: 1.75rem; color: white; }
.benefit-stat { text-align: right; }
.benefit-stat-value { font-size: 1.5rem; font-weight: 800; color: var(--brand); }
.benefit-stat-label { font-size: 0.75rem; color: var(--text-muted); }
.benefit-card h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.75rem; }
.benefit-card p { color: var(--text-muted); line-height: 1.7; font-size: 0.9375rem; }

/* ===== SERVICES ===== */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.service-card { background: var(--card); border-radius: 1rem; border: 1px solid var(--border); overflow: hidden; transition: all 0.3s; }
.service-card:hover { box-shadow: 0 20px 50px rgba(0,0,0,0.1); transform: translateY(-4px); }
.service-bar { height: 0.375rem; width: 100%; }
.service-body { padding: 2rem; }
.service-icon { width: 3.5rem; height: 3.5rem; border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; margin-bottom: 1.25rem; box-shadow: 0 4px 12px rgba(0,0,0,0.15); transition: transform 0.3s; }
.service-card:hover .service-icon { transform: scale(1.1) rotate(3deg); }
.service-icon svg { width: 1.75rem; height: 1.75rem; color: white; }
.service-card h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.75rem; }
.service-card p { color: var(--text-muted); line-height: 1.7; font-size: 0.9375rem; }

/* ===== INDUSTRIES / USE CASES ===== */
.industries-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.industry-card { background: rgba(255,255,255,0.03); backdrop-filter: blur(4px); border-radius: 1rem; padding: 2rem; border: 1px solid rgba(255,255,255,0.1); transition: all 0.3s; }
.industry-card:hover { border-color: rgba(255,255,255,0.25); }
.industry-icon { width: 3.5rem; height: 3.5rem; border-radius: 0.75rem; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; margin-bottom: 1.25rem; transition: transform 0.3s; }
.industry-card:hover .industry-icon { transform: scale(1.1); }
.industry-icon svg { width: 1.75rem; height: 1.75rem; color: var(--brand); }
.industry-card h3 { font-size: 1.25rem; font-weight: 700; color: white; margin-bottom: 0.75rem; }
.industry-card p { color: rgba(255,255,255,0.5); line-height: 1.7; font-size: 0.9375rem; }

/* ===== WHY RV ===== */
.whyrv-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.whyrv-card { background: var(--card); border-radius: 1rem; padding: 2rem; border: 1px solid var(--border); transition: all 0.3s; }
.whyrv-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.08); }
.whyrv-icon { width: 3.5rem; height: 3.5rem; border-radius: 0.75rem; background: linear-gradient(135deg, #fd4f4e, #e53e3d); display: flex; align-items: center; justify-content: center; margin-bottom: 1.5rem; transition: transform 0.3s; }
.whyrv-card:hover .whyrv-icon { transform: scale(1.1); }
.whyrv-icon svg { width: 1.75rem; height: 1.75rem; color: white; }
.whyrv-card h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.75rem; }
.whyrv-card p { color: var(--text-muted); line-height: 1.7; font-size: 0.9375rem; }

/* ===== CASE STUDIES ===== */
.cases-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.case-card { background: var(--card); border-radius: 1rem; border: 1px solid var(--border); overflow: hidden; transition: all 0.3s; }
.case-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
.case-img { height: 12rem; overflow: hidden; position: relative; }
.case-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.case-card:hover .case-img img { transform: scale(1.05); }
.case-badge { position: absolute; top: 1rem; left: 1rem; background: var(--accent); color: white; font-size: 0.75rem; font-weight: 700; padding: 0.25rem 0.75rem; border-radius: 9999px; }
.case-body { padding: 1.5rem; }
.case-card h3 { font-size: 1.125rem; font-weight: 700; margin-bottom: 0.5rem; }
.case-card .desc { font-size: 0.875rem; color: var(--text-muted); margin-bottom: 1rem; line-height: 1.6; }
.case-metrics { display: flex; gap: 1.5rem; }
.case-metric-value { font-size: 1.5rem; font-weight: 700; color: var(--accent); }
.case-metric-label { font-size: 0.75rem; color: var(--text-muted); }

/* ===== PROCESS ===== */
.process-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.process-card { background: var(--card); border-radius: 1rem; padding: 2rem; border: 1px solid var(--border); transition: all 0.3s; position: relative; }
.process-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.08); }
.process-step-num { position: absolute; top: 1.5rem; right: 1.5rem; font-size: 3rem; font-weight: 900; color: color-mix(in srgb, var(--brand) 8%, transparent); }
.process-icon { width: 3.5rem; height: 3.5rem; border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; margin-bottom: 1.5rem; }
.process-icon svg { width: 1.75rem; height: 1.75rem; color: white; }
.process-card h3, .process-card h4 { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.75rem; }
.process-card p { color: var(--text-muted); line-height: 1.7; font-size: 0.9375rem; }

/* ===== INTEGRATIONS ===== */
.integrations-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.integration-group { background: var(--card); border-radius: 1rem; padding: 1.5rem; border: 1px solid var(--border); transition: all 0.3s; }
.integration-group:hover { box-shadow: 0 10px 25px rgba(0,0,0,0.06); }
.integration-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
.integration-dot { width: 0.75rem; height: 0.75rem; border-radius: 50%; }
.integration-header h3 { font-weight: 700; font-size: 1rem; }
.integration-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.integration-tag { padding: 0.375rem 0.75rem; background: var(--bg-muted); color: var(--text); font-size: 0.875rem; border-radius: 0.5rem; font-weight: 500; }

/* ===== TESTIMONIALS ===== */
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.testimonial-card { background: rgba(255,255,255,0.03); backdrop-filter: blur(4px); border-radius: 1rem; padding: 2rem; border: 1px solid rgba(255,255,255,0.1); }
.testimonial-stars { display: flex; gap: 0.25rem; margin-bottom: 1rem; }
.testimonial-stars svg { width: 1.25rem; height: 1.25rem; color: #facc15; fill: #facc15; }
.testimonial-card blockquote { color: rgba(255,255,255,0.7); margin-bottom: 1.5rem; line-height: 1.7; font-style: italic; }
.testimonial-author { color: white; font-weight: 700; }
.testimonial-role { color: rgba(255,255,255,0.5); font-size: 0.875rem; }

/* ===== ENGAGEMENT MODELS ===== */
.engagement-section { padding: 5rem 0; background: linear-gradient(135deg, #0a1628, #1a2d4a); }
.engagement-header { text-align: center; margin-bottom: 4rem; }
.engagement-badge { display: inline-block; padding: 0.5rem 1rem; background: rgba(253,79,78,0.2); color: #fd4f4e; border-radius: 9999px; font-size: 0.875rem; font-weight: 600; margin-bottom: 1rem; }
.engagement-header h2 { font-size: 2rem; font-weight: 700; color: white; margin-bottom: 1rem; }
.engagement-header p { color: rgba(255,255,255,0.7); font-size: 1.125rem; max-width: 48rem; margin: 0 auto; }
.engagement-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; margin-bottom: 4rem; }
.engagement-card { background: rgba(255,255,255,0.1); backdrop-filter: blur(4px); border: 1px solid rgba(255,255,255,0.2); border-radius: 1rem; padding: 1.5rem; transition: background 0.3s; }
.engagement-card:hover { background: rgba(255,255,255,0.15); }
.engagement-card-icon { width: 3rem; height: 3rem; border-radius: 0.75rem; background: rgba(253,79,78,0.2); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.engagement-card-icon svg { width: 1.5rem; height: 1.5rem; color: #fd4f4e; }
.engagement-card h3 { font-size: 1.25rem; font-weight: 700; color: white; margin-bottom: 0.75rem; }
.engagement-card p { color: rgba(255,255,255,0.7); font-size: 0.875rem; margin-bottom: 1rem; }
.engagement-card .ideal { display: flex; align-items: center; gap: 0.5rem; color: #fd4f4e; font-size: 0.875rem; }
.engagement-card .ideal svg { width: 1rem; height: 1rem; }
.engagement-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; margin-bottom: 4rem; }
.engagement-col h3 { font-size: 1.5rem; font-weight: 700; color: white; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 0.75rem; }
.engagement-col h3 svg { width: 2rem; height: 2rem; color: #fd4f4e; }
.engagement-item { display: flex; gap: 1rem; background: rgba(255,255,255,0.05); border-radius: 0.75rem; padding: 1rem; margin-bottom: 1rem; }
.engagement-item-icon { width: 2.5rem; height: 2.5rem; border-radius: 0.5rem; background: rgba(253,79,78,0.1); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.engagement-item-icon svg { width: 1.25rem; height: 1.25rem; color: #fd4f4e; }
.engagement-item h4 { color: white; font-weight: 600; margin-bottom: 0.25rem; }
.engagement-item p { color: rgba(255,255,255,0.6); font-size: 0.875rem; }
.engagement-benefits { background: linear-gradient(to right, rgba(253,79,78,0.2), rgba(253,79,78,0.1)); border: 1px solid rgba(253,79,78,0.3); border-radius: 1rem; padding: 1.5rem; }
.engagement-benefits h4 { color: white; font-weight: 700; margin-bottom: 1rem; }
.engagement-benefits li { display: flex; align-items: center; gap: 0.5rem; color: rgba(255,255,255,0.8); font-size: 0.875rem; margin-bottom: 0.5rem; list-style: none; }
.engagement-benefits .dot { width: 0.375rem; height: 0.375rem; border-radius: 50%; background: #fd4f4e; flex-shrink: 0; }
.engagement-cta { text-align: center; }
.engagement-cta p { color: rgba(255,255,255,0.7); margin-bottom: 1.5rem; }
.btn-accent { display: inline-flex; align-items: center; gap: 0.5rem; background: #fd4f4e; color: white; font-weight: 600; font-size: 1.125rem; padding: 0.875rem 2rem; border-radius: 0.75rem; border: none; cursor: pointer; text-decoration: none; transition: background 0.3s; }
.btn-accent:hover { background: #e04544;color: #fff; }
/* ===== BLOG SECTION ===== */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; max-width: 72rem; margin: 0 auto; }
.blog-card { background: var(--card); border-radius: 0.75rem; overflow: hidden; border: 1px solid var(--border); transition: all 0.3s; text-decoration: none; color: inherit; display: block; }
.blog-card:hover { box-shadow: 0 10px 30px rgba(0,0,0,0.1); transform: translateY(-4px); }
.blog-img { height: 11rem; overflow: hidden; position: relative; }
.blog-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.blog-card:hover .blog-img img { transform: scale(1.05); }
.blog-tag { position: absolute; top: 0.75rem; left: 0.75rem; background: var(--brand); color: white; font-size: 0.75rem; font-weight: 600; padding: 0.25rem 0.75rem; border-radius: 9999px; }
.blog-body { padding: 1.25rem; }
.blog-body h3 { font-size: 1rem; font-weight: 700; margin-bottom: 0.75rem; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; transition: color 0.3s; }
.blog-card:hover h3 { color: var(--accent); }
.blog-body p { font-size: 0.875rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 1rem; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.blog-read { color: var(--accent); font-weight: 600; font-size: 0.875rem; }

/* ===== FAQ ===== */
.faq-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; align-items: start; }
.faq-item { background: var(--card); border: 1px solid var(--border); border-radius: 0.75rem; overflow: hidden; transition: border-color 0.3s; }
.faq-item.open { border-color: rgba(253,79,78,0.5); }
.faq-question { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 1.25rem 1.5rem; background: transparent; border: none; cursor: pointer; text-align: left; font-weight: 600; font-size: 1rem; color: var(--text); transition: color 0.3s; font-family: inherit; }
.faq-question:hover { color: var(--accent); }
.faq-question svg { width: 1.25rem; height: 1.25rem; color: var(--text-muted); transition: transform 0.3s; flex-shrink: 0; margin-left: 1rem; }
.faq-item.open .faq-question svg { transform: rotate(180deg); color: var(--accent); }
.faq-answer { display: none; padding: 0 1.5rem 1.25rem; color: var(--text-muted); line-height: 1.7; font-size: 0.9375rem; }
.faq-item.open .faq-answer { display: block; }

/* ===== CONTACT ===== */
.contact-section { padding: 5rem 0; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; max-width: 72rem; margin: 0 auto; }
.contact-info h2 { font-size: 2.5rem; font-weight: 700; margin-bottom: 1rem; }
.contact-info p { color: var(--text-muted); font-size: 1.125rem; margin-bottom: 2rem; }
.contact-detail { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.contact-detail-icon { width: 3rem; height: 3rem; border-radius: 0.75rem; background: rgba(253,79,78,0.1); display: flex; align-items: center; justify-content: center; }
.contact-detail-icon svg { width: 1.25rem; height: 1.25rem; color: var(--accent); }
.contact-form { background: var(--bg-muted); border-radius: 1rem; padding: 2rem; }
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-weight: 600; font-size: 0.875rem; margin-bottom: 0.5rem; }
.form-group input, .form-group textarea, .form-group select { width: 100%; padding: 0.75rem 1rem; border: 1px solid var(--border); border-radius: 0.5rem; font-family: inherit; font-size: 1rem; transition: border-color 0.3s; background: white; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--brand); }
.form-group textarea { resize: vertical; min-height: 120px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.btn-submit { width: 100%; padding: 1rem; background: var(--accent); color: white; font-weight: 600; font-size: 1rem; border: none; border-radius: 0.5rem; cursor: pointer; transition: background 0.3s; font-family: inherit; }
.btn-submit:hover { background: #e04544; }

/* ===== INTEGRATION CATEGORIES (alternate class names used in pages) ===== */
.integration-category { background: var(--card); border-radius: 1rem; padding: 1.5rem; border: 1px solid var(--border); transition: all 0.3s; overflow: hidden; }
.integration-category:hover { box-shadow: 0 10px 25px rgba(0,0,0,0.06); }
.integration-bar { height: 0.25rem; width: 100%; border-radius: 9999px; margin-bottom: 1rem; }
.integration-category h4 { font-weight: 700; font-size: 1rem; margin-bottom: 1rem; }
.integration-items { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.integration-item { padding: 0.375rem 0.75rem; background: var(--bg-muted); color: var(--text); font-size: 0.875rem; border-radius: 0.5rem; font-weight: 500; }

/* ===== PROCESS STEP NUMBERS ===== */
.process-step { width: 3rem; height: 3rem; border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; margin-bottom: 1.5rem; color: white; font-weight: 800; font-size: 1.25rem; }

/* ===== ENGAGEMENT SECTION (alternate class) ===== */
.section-engagement { padding: 5rem 0; background: linear-gradient(135deg, #0a1628, #1a2d4a); color: white; }
.section-engagement .section-title { color: white; }
.section-engagement .section-subtitle { color: rgba(255,255,255,0.5); }
.section-engagement .section-badge { border: 1px solid rgba(255,255,255,0.2); color: rgba(255,255,255,0.7); }
.section-engagement .engagement-card { background: rgba(255,255,255,0.05); backdrop-filter: blur(4px); border: 1px solid rgba(255,255,255,0.1); border-radius: 1rem; padding: 1.5rem; transition: background 0.3s; }
.section-engagement .engagement-card:hover { background: rgba(255,255,255,0.1); }
.section-engagement .engagement-icon { width: 3rem; height: 3rem; border-radius: 0.75rem; background: rgba(253,79,78,0.2); display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.section-engagement .engagement-icon svg { width: 1.5rem; height: 1.5rem; color: #fd4f4e; }
.section-engagement .engagement-card h4 { font-size: 1.25rem; font-weight: 700; color: white; margin-bottom: 0.75rem; }
.section-engagement .engagement-card p { color: rgba(255,255,255,0.7); font-size: 0.875rem; margin-bottom: 1rem; }
.section-engagement .engagement-card ul { list-style: none; padding: 0; }
.section-engagement .engagement-card ul li { display: flex; align-items: center; gap: 0.5rem; color: rgba(255,255,255,0.6); font-size: 0.875rem; margin-bottom: 0.375rem; }
.section-engagement .engagement-card ul li::before { content: '✓'; color: #fd4f4e; font-weight: 700; }

/* ===== CASE CARD DIRECT IMG ===== */
.case-card > img { width: 100%; height: 12rem; object-fit: cover; transition: transform 0.5s; }
.case-card:hover > img { transform: scale(1.05); }
.case-stats { display: flex; gap: 1.5rem; margin-top: 1rem; }
.case-stats span { font-size: 0.875rem; font-weight: 600; color: var(--accent); }

/* ===== INDUSTRY CARD h4 fix ===== */
/* ===== HUBSPOT-SPECIFIC: Color aliases ===== */
.section-title .hubspot { color: var(--brand); }
.section-badge-hubspot { background: color-mix(in srgb, var(--brand) 10%, transparent); color: var(--brand); }

/* ===== HUBSPOT HERO (alternate layout with image) ===== */
.hero-content { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center; width: 100%; }
.hero-glow-1 { position: absolute; top: 25%; left: 25%; width: 24rem; height: 24rem; background: rgba(255,122,89,0.1); border-radius: 50%; filter: blur(48px); }
.hero-glow-2 { position: absolute; bottom: 25%; right: 25%; width: 20rem; height: 20rem; background: rgba(0,145,174,0.1); border-radius: 50%; filter: blur(48px); }
.hero-badge-icon { width: 2rem; height: 2rem; background: var(--brand); border-radius: 0.5rem; display: flex; align-items: center; justify-content: center; }
.hero-badge-icon svg { width: 1rem; height: 1rem; color: white; }
.hero h1 .white { color: white; }
.hero h1 .orange { color: var(--brand); }
.btn-primary { display: inline-flex; align-items: center; gap: 0.5rem; background: var(--brand); color: white; font-weight: 600; font-size: 1rem; padding: 0.875rem 2rem; border-radius: 9999px; border: none; cursor: pointer; text-decoration: none; box-shadow: 0 10px 25px rgba(0,0,0,0.2); transition: background 0.3s; }
.btn-primary:hover { filter: brightness(1.1); }
.hero-image { display: flex; align-items: center; justify-content: center; position: relative; }
.hero-image-glow { position: absolute; inset: 0; background: rgba(255,122,89,0.1); filter: blur(100px); border-radius: 50%; transform: scale(0.9); }
.hero-image img { position: relative; width: 100%; max-width: 36rem; border-radius: 1rem; overflow: hidden; box-shadow: 0 25px 50px rgba(0,0,0,0.3); border: 1px solid rgba(255,255,255,0.1); }

/* ===== SERVICE FEATURES (HubSpot 4-col grid) ===== */
.services-grid.max-w-7xl { grid-template-columns: repeat(4, 1fr); }
.service-card-hover-bg { position: absolute; inset: 0; background: linear-gradient(to bottom right, rgba(253,79,78,0.05), transparent); opacity: 0; transition: opacity 0.3s; }
.service-card:hover .service-card-hover-bg { opacity: 1; }
.service-card .desc { font-size: 0.875rem; color: var(--text-muted); margin-bottom: 1rem; position: relative; z-index: 1; }
.service-features { list-style: none; position: relative; z-index: 1; }
.service-features li { display: flex; align-items: center; gap: 0.5rem; font-size: 0.875rem; color: var(--text-muted); margin-bottom: 0.5rem; }
.service-features li svg { width: 1rem; height: 1rem; color: var(--accent); flex-shrink: 0; }
.service-card h3 { position: relative; z-index: 1; }

/* ===== ECOSYSTEM / HUB CARDS ===== */
.max-w-6xl { max-width: 72rem; margin: 0 auto; }
.ecosystem-header-actions { display: flex; justify-content: center; margin-top: 1.5rem; }
.btn-expand { display: inline-flex; align-items: center; gap: 0.5rem; background: transparent; border: 2px solid color-mix(in srgb, var(--brand) 30%, transparent); color: var(--brand); font-weight: 500; padding: 0.625rem 1.5rem; border-radius: 9999px; cursor: pointer; font-size: 0.875rem; transition: background 0.3s; }
.btn-expand:hover { background: color-mix(in srgb, var(--brand) 10%, transparent); }
.btn-expand svg { width: 1rem; height: 1rem; transition: transform 0.3s; }
.btn-expand.expanded svg { transform: rotate(180deg); }
.ecosystem-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; align-items: start; }
.hub-card { background: var(--card); border-radius: 1rem; border: 1px solid var(--border); overflow: hidden; transition: all 0.3s; }
.hub-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.08); border-color: color-mix(in srgb, var(--brand) 30%, transparent); }
.hub-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.5rem; cursor: pointer; transition: background 0.3s; border: none; background: transparent; width: 100%; text-align: left; }
.hub-header:hover { background: rgba(0,0,0,0.02); }
.hub-header-left { display: flex; align-items: center; gap: 1rem; }
.hub-icon { width: 3.5rem; height: 3.5rem; border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.hub-icon svg { width: 1.75rem; height: 1.75rem; color: white; }
.hub-title { font-size: 1.5rem; font-weight: 700; color: var(--text); }
.hub-desc { font-size: 0.875rem; color: var(--text-muted); }
.hub-chevron { transition: transform 0.3s; }
.hub-chevron svg { width: 1.5rem; height: 1.5rem; color: var(--text-muted); }
.hub-card.expanded .hub-chevron { transform: rotate(180deg); }
.hub-apps { display: none; grid-template-columns: repeat(2, 1fr); gap: 1rem; padding: 0 1.5rem 1.5rem; border-top: 1px solid var(--border); padding-top: 1.5rem; }
.hub-card.expanded .hub-apps { display: grid; }
.hub-app { display: flex; align-items: flex-start; gap: 1rem; padding: 1rem; border-radius: 0.75rem; background: var(--bg-muted); transition: background 0.3s; }
.hub-app:hover { background: #f0f0f5; }
.hub-app-icon { width: 3rem; height: 3rem; border-radius: 0.5rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.hub-app-icon svg { width: 1.5rem; height: 1.5rem; color: white; }
.hub-app h4 { font-weight: 600; font-size: 1rem; color: var(--text); transition: color 0.3s; }
.hub-app:hover h4 { color: var(--brand); }
.hub-app p { font-size: 0.875rem; color: var(--text-muted); margin-top: 0.25rem; line-height: 1.5; }

/* ===== DIFF / WHY CHOOSE US ===== */
.diff-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.diff-card { position: relative; background: var(--card); border-radius: 1rem; border: 1px solid var(--border); padding: 1.5rem; transition: all 0.3s; overflow: hidden; }
.diff-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.08); border-color: rgba(253,79,78,0.4); transform: translateY(-5px); }
.diff-card-circle { position: absolute; right: -1.5rem; top: -1.5rem; width: 6rem; height: 6rem; background: rgba(253,79,78,0.05); border-radius: 50%; transition: background 0.3s; }
.diff-card:hover .diff-card-circle { background: rgba(253,79,78,0.1); }
.diff-content { display: flex; align-items: flex-start; gap: 1rem; position: relative; z-index: 1; }
.diff-icon { width: 3.5rem; height: 3.5rem; background: rgba(253,79,78,0.1); border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all 0.3s; }
.diff-card:hover .diff-icon { background: var(--accent); }
.diff-icon svg { width: 1.75rem; height: 1.75rem; color: var(--accent); transition: color 0.3s; }
.diff-card:hover .diff-icon svg { color: white; }
.diff-highlight { display: inline-block; background: rgba(253,79,78,0.1); color: var(--accent); font-size: 0.75rem; font-weight: 600; padding: 0.125rem 0.5rem; border-radius: 9999px; margin-bottom: 0.5rem; }
.diff-card h3 { font-weight: 700; font-size: 1.125rem; margin-bottom: 0.25rem; }
.diff-card .desc { font-size: 0.875rem; color: var(--text-muted); line-height: 1.6; }

/* ===== PRICING ===== */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.pricing-card { background: var(--card); border-radius: 1rem; padding: 2rem; transition: all 0.3s; position: relative; overflow: hidden; border: 1px solid var(--border); }
.pricing-card.featured { border: 2px solid var(--brand); box-shadow: 0 10px 30px rgba(0,0,0,0.1); }
.pricing-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
.pricing-badge { position: absolute; top: 0; right: 0; color: white; font-size: 0.75rem; font-weight: 700; padding: 0.25rem 1rem; border-bottom-left-radius: 0.75rem; }
.pricing-icon { width: 4rem; height: 4rem; border-radius: 1rem; display: flex; align-items: center; justify-content: center; margin-bottom: 1.5rem; }
.pricing-icon svg { width: 2rem; height: 2rem; }
.pricing-card h3 { font-size: 1.5rem; font-weight: 700; margin-bottom: 0.75rem; }
.pricing-card .desc { color: var(--text-muted); margin-bottom: 1.5rem; }
.pricing-features { list-style: none; }
.pricing-features li { display: flex; align-items: flex-start; gap: 0.75rem; margin-bottom: 0.75rem; font-size: 0.875rem; }
.pricing-features li svg { width: 1.25rem; height: 1.25rem; margin-top: 0.125rem; flex-shrink: 0; }
.pricing-best-for { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border); font-size: 0.75rem; color: var(--text-muted); }

/* ===== HUBSPOT PROCESS (dark section variant) ===== */
.section-dark .process-card { background: rgba(255,255,255,0.1); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,0.2); }
.section-dark .process-card .desc { color: rgba(255,255,255,0.7); }
.process-step-num { position: absolute; top: -0.75rem; left: -0.75rem; width: 3rem; height: 3rem; border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; color: white; font-weight: 700; font-size: 1.125rem; box-shadow: 0 4px 12px rgba(0,0,0,0.2); }
.process-duration { display: inline-flex; align-items: center; gap: 0.5rem; background: rgba(255,255,255,0.1); border-radius: 9999px; padding: 0.375rem 0.75rem; font-size: 0.875rem; font-weight: 500; }
.process-duration svg { width: 1rem; height: 1rem; color: var(--accent); }

/* ===== HUBSPOT INDUSTRIES (8-col grid variant) ===== */
.industries-grid-8 { display: grid; grid-template-columns: repeat(8, 1fr); gap: 1rem; }
.industry-item { display: flex; flex-direction: column; align-items: center; text-align: center; cursor: pointer; transition: transform 0.3s; }
.industry-item:hover { transform: scale(1.1) translateY(-5px); }
.industry-item .industry-icon { margin-bottom: 0.75rem; }
.industry-item span { font-size: 0.75rem; font-weight: 500; transition: color 0.3s; }
.industry-item:hover span { color: var(--accent); }

/* ===== HUBSPOT CASE STUDIES (alternate class names) ===== */
.case-card-img { height: 12rem; overflow: hidden; }
.case-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.case-card:hover .case-card-img img { transform: scale(1.05); }
.case-card-body { padding: 1.5rem; }
.case-card-category { font-size: 0.75rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.05em; }

/* ===== CTA SECTION ===== */
.cta-section { padding: 5rem 0; background: var(--primary, #1B2A4A); position: relative; overflow: hidden; }
.cta-dots { position: absolute; inset: 0; opacity: 0.1; background-image: radial-gradient(circle at 2px 2px, white 1px, transparent 0); background-size: 30px 30px; }
.cta-content { position: relative; z-index: 10; text-align: center; max-width: 48rem; margin: 0 auto; }
.cta-content h2 { font-size: 2.5rem; font-weight: 700; color: white; margin-bottom: 1.5rem; }
.cta-content p { color: rgba(255,255,255,0.9); font-size: 1.125rem; margin-bottom: 2rem; max-width: 32rem; margin-left: auto; margin-right: auto; }
.cta-buttons { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .hero-grid, .hero-content { grid-template-columns: 1fr; }
  .hero-cards, .hero-image { display: none; }
  .hero h1 { font-size: 2.75rem; }
  .benefits-grid, .services-grid, .services-grid.max-w-7xl, .whyrv-grid, .process-grid { grid-template-columns: repeat(2, 1fr); }
  .industries-grid { grid-template-columns: repeat(2, 1fr); }
  .industries-grid-8 { grid-template-columns: repeat(4, 1fr); }
  .cases-grid { grid-template-columns: 1fr; max-width: 32rem; margin: 0 auto; }
  .testimonials-grid { grid-template-columns: 1fr; max-width: 32rem; margin: 0 auto; }
  .integrations-grid { grid-template-columns: repeat(2, 1fr); }
  .engagement-grid { grid-template-columns: repeat(2, 1fr); }
  .engagement-columns { grid-template-columns: 1fr; }
  .faq-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; max-width: 32rem; margin: 0 auto; }
  .contact-grid { grid-template-columns: 1fr; }
  .section-title { font-size: 2rem; }
  .diff-grid { grid-template-columns: repeat(2, 1fr); }
  .pricing-grid { grid-template-columns: 1fr; max-width: 28rem; margin: 0 auto; }
  .ecosystem-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .hero h1 { font-size: 2.25rem; }
  .hero-stats { gap: 1rem; }
  .benefits-grid, .services-grid, .services-grid.max-w-7xl, .whyrv-grid, .process-grid, .industries-grid { grid-template-columns: 1fr; }
  .engagement-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .diff-grid { grid-template-columns: 1fr; }
  .hub-apps { grid-template-columns: 1fr; }
  .industries-grid-8 { grid-template-columns: repeat(3, 1fr); }
}
