/* ============================================
   BRANDFLOW WEBSITE - STYLES
   Modern, responsive design with glassmorphism
   ============================================ */

/* ============================================
   CSS VARIABLES / CUSTOM PROPERTIES
   ============================================ */
:root {
    /* Colors - Primary: White, Secondary: Navy, Accent: Orange */
    --color-white: #ffffff;
    --color-orange: #f97316;
    --color-orange-dark: #ea580c;
    --color-orange-light: #fb923c;
    --color-orange-lighter: rgba(249, 115, 22, 0.1);
    --color-navy: #1e3a5f;
    --color-navy-dark: #0f2744;
    --color-navy-light: #2d4a6f;
    --color-text-dark: #0f2744;
    --color-text-light: #64748b;
    --color-text-lighter: #94a3b8;
    --color-bg-light: #f8fafc;
    --color-bg-lighter: #f1f5f9;
    --color-border: #e2e8f0;

    /* Solid Colors - Navy for buttons, Orange for accents */
    --solid-orange: #f97316;
    --solid-navy: #1e3a5f;
    --solid-navy-dark: #0f2744;
    
    /* Spacing */
    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 2rem;
    --spacing-lg: 3rem;
    --spacing-xl: 4rem;
    --spacing-2xl: 6rem;
    
    /* Typography */
    --font-body: 'Inter', sans-serif;
    --font-heading: 'Poppins', sans-serif;
    
    /* Transitions */
    --transition-fast: 0.2s ease;
    --transition-normal: 0.3s ease;
    --transition-slow: 0.5s ease;
    
    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    
    /* Border Radius - Modern square design */
    --radius-sm: 0.125rem;
    --radius-md: 0.25rem;
    --radius-lg: 0.25rem;
    --radius-xl: 0.375rem;
    --radius-2xl: 0.5rem;
    --radius-full: 9999px;
    
    /* Z-index layers */
    --z-dropdown: 1000;
    --z-sticky: 1020;
    --z-fixed: 1030;
    --z-modal-backdrop: 1040;
    --z-modal: 1050;
    --z-popover: 1060;
    --z-tooltip: 1070;
}

/* ============================================
   DECORATIVE BACKGROUND SHAPES
   Large abstract geometric shapes for modern design
   ============================================ */

/* Large abstract shapes for features section */
.features {
    position: relative;
}

.features::before {
    content: '';
    position: absolute;
    top: -20%;
    left: -15%;
    width: 600px;
    height: 600px;
    background: linear-gradient(135deg, rgba(30, 58, 95, 0.04) 0%, transparent 60%);
    transform: rotate(-15deg);
    z-index: 0;
}

.features::after {
    content: '';
    position: absolute;
    bottom: -30%;
    right: -10%;
    width: 500px;
    height: 700px;
    background: linear-gradient(45deg, rgba(249, 115, 22, 0.03) 0%, transparent 50%);
    transform: rotate(20deg) skewY(-10deg);
    z-index: 0;
}

/* Large abstract shapes for services section */
.services::before {
    content: '';
    position: absolute;
    top: -10%;
    right: -20%;
    width: 800px;
    height: 500px;
    background: linear-gradient(160deg, rgba(30, 58, 95, 0.03) 0%, transparent 50%);
    transform: rotate(10deg);
    z-index: 0;
}

.services::after {
    content: '';
    position: absolute;
    bottom: -25%;
    left: -25%;
    width: 700px;
    height: 600px;
    background: linear-gradient(-45deg, rgba(249, 115, 22, 0.04) 0%, transparent 40%);
    transform: skewX(-15deg);
    z-index: 0;
}

/* Large abstract shapes for pricing section */
.pricing::before {
    content: '';
    position: absolute;
    top: 5%;
    left: -30%;
    width: 900px;
    height: 400px;
    background: linear-gradient(120deg, rgba(30, 58, 95, 0.04) 0%, transparent 45%);
    transform: rotate(-8deg) skewY(5deg);
    z-index: 0;
}

.pricing::after {
    content: '';
    position: absolute;
    bottom: -15%;
    right: -15%;
    width: 600px;
    height: 800px;
    background: linear-gradient(-30deg, rgba(249, 115, 22, 0.03) 0%, transparent 50%);
    transform: rotate(15deg);
    z-index: 0;
}

/* Large abstract shapes for contact section */
.contact::before {
    content: '';
    position: absolute;
    top: -15%;
    right: -25%;
    width: 700px;
    height: 700px;
    background: linear-gradient(200deg, rgba(30, 58, 95, 0.04) 0%, transparent 50%);
    transform: rotate(25deg);
    z-index: 0;
}

.contact::after {
    content: '';
    position: absolute;
    bottom: -20%;
    left: -20%;
    width: 800px;
    height: 500px;
    background: linear-gradient(30deg, rgba(249, 115, 22, 0.03) 0%, transparent 45%);
    transform: skewX(10deg) rotate(-5deg);
    z-index: 0;
}

/* Large abstract shapes for projects section */
.projects::after {
    content: '';
    position: absolute;
    bottom: -25%;
    right: -20%;
    width: 700px;
    height: 600px;
    background: linear-gradient(-60deg, rgba(249, 115, 22, 0.04) 0%, transparent 50%);
    transform: rotate(-10deg) skewY(8deg);
    z-index: 0;
}

/* Large abstract shapes for industries section */
.industries::before {
    content: '';
    position: absolute;
    top: -10%;
    left: -15%;
    width: 500px;
    height: 500px;
    background: linear-gradient(140deg, rgba(30, 58, 95, 0.04) 0%, transparent 55%);
    transform: rotate(-20deg);
    z-index: 0;
}

.industries::after {
    content: '';
    position: absolute;
    bottom: -30%;
    right: -25%;
    width: 600px;
    height: 700px;
    background: linear-gradient(-50deg, rgba(249, 115, 22, 0.03) 0%, transparent 45%);
    transform: skewX(-8deg) rotate(12deg);
    z-index: 0;
}

/* ============================================
   BASE & RESET
   ============================================ */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* Iconify Icon Styles */
iconify-icon {
    display: inline-block;
    vertical-align: middle;
    color: inherit;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    height: 100%;
    width: 100%;
    /* Prevent overscroll bounce on iOS/Android */
    overscroll-behavior: auto;
}

/* Preserve comfortable notches/safe-area spacing on modern phones */
:root {
    --safe-area-top: env(safe-area-inset-top, 0px);
    --safe-area-right: env(safe-area-inset-right, 0px);
    --safe-area-bottom: env(safe-area-inset-bottom, 0px);
    --safe-area-left: env(safe-area-inset-left, 0px);
}

body {
    font-family: var(--font-body);
    color: var(--color-text-dark);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    overflow-y: hidden;
    min-height: 100%;
    width: 100%;
    max-width: 100vw;
    /* Optimize scroll performance */
    overscroll-behavior-y: auto;
    -webkit-overflow-scrolling: auto;
    position: relative;
    overflow-wrap: break-word;
    word-break: normal;
}

main {
    display: block;
    overflow: visible;
}

/* Performance optimizations */
img,
iframe {
    content-visibility: auto;
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    text-decoration: none;
    color: inherit;
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: none;
}

ul {
    list-style: none;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-text-dark);
}

h1 {
    font-size: clamp(2rem, 5vw, 3.5rem);
}

h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
}

h3 {
    font-size: clamp(1.25rem, 3vw, 1.75rem);
}

p {
    margin-bottom: 1rem;
}

/* ============================================
   LAYOUT UTILITIES
   ============================================ */
.container {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding-inline: clamp(1rem, 3vw, 2rem);
}

/* ============================================
   EDITORIAL LAYOUT UTILITIES
   ============================================ */

/* Full-bleed dark navy section */
.section--navy {
    background: var(--color-navy-dark);
    width: 100%;
}

.section--navy .section__title,
.section--navy h2,
.section--navy h3 {
    color: var(--color-white);
}

.section--navy .section__subtitle,
.section--navy p {
    color: rgba(255, 255, 255, 0.72);
}

.section--navy .section__tag,
.section--navy .section__badge {
    color: rgba(255, 255, 255, 0.65);
    background: none;
    border-color: rgba(249, 115, 22, 0.7);
}

/* Light alternate section used across service + pricing pages */
.section--alt {
    background: var(--color-bg-light);
}

/* Asymmetric two-column preview grid */
.preview-cards__asymmetric-grid {
    display: grid;
    grid-template-columns: 1.25fr 1fr;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.preview-cards__right-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.preview-cards__cta-row {
    margin-top: 0;
}

/* Large featured card */
.preview-card--large {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 420px;
    background: var(--color-navy-dark) !important;
    color: var(--color-white);
    padding: 2.5rem !important;
    position: relative;
    overflow: hidden;
    border-color: transparent !important;
    border-radius: 0 !important;
}

.preview-card--large::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -60px;
    width: 220px;
    height: 220px;
    background: var(--color-orange);
    transform: rotate(45deg);
    opacity: 0.07;
    pointer-events: none;
}

.preview-card--large::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--color-orange);
}

.preview-card--large .preview-card__title {
    color: var(--color-white);
    font-size: 1.5rem;
}

.preview-card--large .preview-card__text {
    color: rgba(255, 255, 255, 0.75);
}

.preview-card--large .preview-card__icon {
    background: rgba(249, 115, 22, 0.2) !important;
    color: var(--color-orange);
}

.preview-card--large .preview-card__link {
    color: var(--color-orange);
    font-size: 1rem;
}

.preview-card--large:hover {
    transform: none !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2) !important;
    border-color: transparent !important;
}

/* CTA advisor horizontal card */
.preview-card--advisor-cta {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    justify-content: space-between;
    background: var(--color-orange) !important;
    color: var(--color-white) !important;
    padding: 1.75rem 2.5rem !important;
    border-radius: 0 !important;
    border-color: transparent !important;
    gap: 2rem;
}

.preview-card--advisor-cta .preview-card__title {
    color: var(--color-white);
    font-size: 1.25rem;
    margin-bottom: 0.25rem;
}

.preview-card--advisor-cta .preview-card__text {
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 0;
    flex-grow: 0;
}

.preview-card--advisor-cta .preview-card__icon {
    background: rgba(255, 255, 255, 0.2) !important;
    flex-shrink: 0;
}

.preview-card--advisor-cta .preview-card__link {
    color: var(--color-white);
    font-size: 1rem;
    font-weight: 700;
    flex-shrink: 0;
    white-space: nowrap;
}

.preview-card--advisor-cta:hover {
    background: var(--color-orange-dark) !important;
    transform: none !important;
    box-shadow: 0 10px 40px rgba(249, 115, 22, 0.3) !important;
    border-color: transparent !important;
}

/* Standard preview card sharpened */
.preview-card {
    border-radius: 0 !important;
}

.section {
    padding: var(--spacing-2xl) 0;
}

.section__header {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.section__title {
    margin-bottom: var(--spacing-sm);
    color: var(--color-navy);
}

.section__subtitle {
    color: var(--color-text-light);
    font-size: 1.125rem;
    max-width: 600px;
    margin: 0 auto;
}

/* Top scroll progress indicator */
.scroll-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0;
    background: linear-gradient(90deg, #f97316 0%, #fb923c 100%);
    z-index: calc(var(--z-fixed) + 20);
    transition: width 0.14s linear;
    pointer-events: none;
}

/* ============================================
   HEADER / NAVIGATION
   ============================================ */
.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: var(--z-fixed);
    transition: all var(--transition-normal);
    background: rgba(255, 255, 255, 0.98);
    border-bottom: 1px solid var(--color-border);
    border-top: 3px solid var(--color-orange);
    box-shadow: 0 2px 20px rgba(15, 39, 68, 0.08);
}

.header.scrolled {
    background: rgba(255, 255, 255, 0.95);
    border-bottom-color: var(--color-border);
    box-shadow: var(--shadow-md);
}

/* Keep nav link colors consistent in static and scrolled states */
.header:not(.scrolled) .nav__link {
    color: var(--color-navy);
}

.header:not(.scrolled) .nav__link:hover,
.header:not(.scrolled) .nav__link.active {
    color: var(--color-orange);
}

.header:not(.scrolled) .nav__link::after {
    background: var(--color-orange);
}

.header:not(.scrolled) .nav__toggle span {
    background: var(--color-navy);
}

.nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 88px;
}

.nav__logo-img {
    height: 72px;
    width: auto;
    transition: height var(--transition-normal);
}

.header.scrolled .nav__logo-img {
    height: 58px;
}

.nav__list {
    display: flex;
    gap: 2rem;
    align-items: center;
}

.nav__link {
    font-weight: 500;
    font-size: 0.875rem;
    letter-spacing: 0.5px;
    color: var(--color-navy);
    transition: color var(--transition-fast);
    position: relative;
}

.nav__link::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--color-orange);
    transition: width var(--transition-normal);
}

.nav__link:hover,
.nav__link.active {
    color: var(--color-orange);
}

.nav__link:hover::after,
.nav__link.active::after {
    width: 100%;
}

/* Dropdown Navigation Styles */
.nav__item {
    position: relative;
}

.nav__item--dropdown {
    position: relative;
}

.nav__dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--color-white);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-xl);
    padding: 0.5rem 0;
    min-width: 180px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all var(--transition-normal);
    z-index: var(--z-dropdown);
    margin-top: 0.5rem;
    border: 1px solid var(--color-border);
}

/* Dropdown stays white even when header is transparent */
.header:not(.scrolled) .nav__dropdown {
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.nav__item--dropdown:hover .nav__dropdown,
.nav__item--dropdown.active .nav__dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.nav__item--dropdown.active .nav__link--dropdown iconify-icon {
    transform: rotate(180deg);
}

.nav__dropdown-link {
    display: block;
    padding: 0.75rem 1.25rem;
    color: var(--color-navy);
    font-size: 0.875rem;
    font-weight: 500;
    transition: all var(--transition-fast);
}

.nav__dropdown-link:hover {
    background: var(--color-bg-light);
    color: var(--color-orange);
}

.nav__link--dropdown {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}

.nav__link--dropdown iconify-icon {
    transition: transform var(--transition-fast);
    margin-top: 2px;
}

.nav__item--dropdown:hover .nav__link--dropdown iconify-icon {
    transform: rotate(180deg);
}

/* Contact Button in Nav */
.nav__link--btn {
    background: var(--solid-navy);
    color: var(--color-white);
    padding: 0.625rem 1.5rem;
    border-radius: var(--radius-lg);
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    isolation: isolate;
}

.nav__link--btn::before {
    content: '';
    position: absolute;
    inset: 0;
    width: 120%;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.4) 50%, transparent 100%);
    transform: translateX(-150%);
    transition: transform 0.9s ease;
    pointer-events: none;
}

.nav__link--btn:hover::before {
    transform: translateX(150%);
}

.nav__link--btn:hover {
    background: var(--solid-navy-dark);
    transform: translateY(-2px);
}

.nav__link--btn::after {
    display: none;
}

/* Contact button always white text */
.nav__link--btn,
.nav__link--btn.active,
.nav__link--btn:hover,
.nav__link--btn.active:hover,
.header:not(.scrolled) .nav__link--btn,
.header:not(.scrolled) .nav__link--btn.active,
.header:not(.scrolled) .nav__link--btn:hover,
.header:not(.scrolled) .nav__link--btn.active:hover,
.header.scrolled .nav__link--btn,
.header.scrolled .nav__link--btn.active,
.header.scrolled .nav__link--btn:hover {
    color: var(--color-white);
}

/* AI Advisor Highlight Button in Nav */
.nav__link--highlight {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: var(--color-orange);
    color: var(--color-white) !important;
    padding: 0.5rem 1.15rem;
    border-radius: var(--radius-sm);
    font-weight: 700;
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    position: relative;
    overflow: hidden;
    transition: all var(--transition-fast);
    border: 1px solid rgba(234, 88, 12, 0.8);
    box-shadow: 0 6px 16px rgba(249, 115, 22, 0.22);
}

.nav__link--highlight::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.24) 50%, transparent 100%);
    transform: translateX(-150%);
    transition: transform 0.6s ease;
}

.nav__link--highlight:hover::before {
    transform: translateX(150%);
}

.nav__link--highlight:hover {
    background: var(--color-orange-dark);
    border-color: var(--color-orange-dark);
    transform: translateY(-1px);
}

.nav__link--highlight::after {
    display: none;
}

/* Highlight nav always orange/white regardless of scroll state */
.header:not(.scrolled) .nav__link--highlight,
.header.scrolled .nav__link--highlight {
    color: var(--color-white) !important;
}

/* Mobile Navigation Toggle */
.nav__toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
}

.nav__toggle span {
    width: 25px;
    height: 2px;
    background: var(--color-navy);
    transition: all var(--transition-fast);
}

.nav__toggle.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.nav__toggle.active span:nth-child(2) {
    opacity: 0;
}

.nav__toggle.active span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -6px);
}

/* ============================================
   HERO SECTION — Full-width asymmetric split
   ============================================ */
.hero {
    position: relative;
    min-height: 88vh;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr;
    padding-top: 88px;
}

.hero__split {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    min-height: calc(88vh - 88px);
}

.hero__split-left {
    background: var(--color-navy-dark);
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero__split-left::before {
    content: '';
    position: absolute;
    top: -15%;
    left: -10%;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(249, 115, 22, 0.08) 0%, transparent 65%);
    pointer-events: none;
}

.hero__split-left__inner {
    padding: clamp(2.5rem, 5vw, 5.5rem) clamp(1.5rem, 4vw, 4.5rem);
    max-width: min(760px, 100%);
    padding: clamp(2.5rem, 6vw, 5rem) clamp(1.5rem, 5vw, 4rem);
    max-width: 580px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.hero__eyebrow {
    display: inline-block;
    background: none;
    border: none;
    border-top: 2px solid rgba(249, 115, 22, 0.8);
    border-radius: 0;
    padding: 0.45rem 0 0;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    box-shadow: none;
    margin-bottom: 1.75rem;
}

.hero__split-right {
    background: var(--color-bg-light);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(2rem, 5vw, 4rem) clamp(1.25rem, 4vw, 3rem);
    position: relative;
    overflow: hidden;
}

.hero__split-right::before {
    content: '';
    position: absolute;
    bottom: -10%;
    right: -10%;
    width: 350px;
    height: 350px;
    background: radial-gradient(circle, rgba(249, 115, 22, 0.06) 0%, transparent 65%);
    pointer-events: none;
}

/* Legacy container within hero for SVG */
.hero__container {
    position: relative;
    z-index: 1;
    width: 100%;
}

.hero__inner {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: var(--spacing-xl);
    align-items: center;
    min-height: calc(100vh - 88px);
}

.hero__content {
    max-width: 560px;
    text-align: left;
}

.hero__split-left__inner .hero__content {
    max-width: 100%;
    padding: 0;
}

/* Hero Badge */
.hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.875rem;
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: var(--color-white);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: var(--spacing-lg);
}

.hero__badge svg {
    color: var(--color-orange-light);
}

.hero__title {
    color: var(--color-white);
    margin-bottom: var(--spacing-md);
    line-height: 1.08;
    font-size: clamp(2rem, 3.6vw, 3.6rem);
    letter-spacing: -0.01em;
}

.hero__title-rotator {
    display: block;
    position: relative;
    min-height: 2.5em;
    max-width: 100%;
    width: 100%;
    transition: height 0.6s ease;
    will-change: height;
}

.hero__title-rotating {
    display: inline-block;
    white-space: normal;
    transform: translateX(40px);
    opacity: 0;
    transition: transform 0.6s ease, opacity 0.6s ease;
    max-width: 100%;
    line-height: 1.2;
}

.hero__title-rotating.is-in {
    transform: translateX(0);
    opacity: 1;
}

.hero__title-rotating.is-out {
    transform: translateX(-40px);
    opacity: 0;
}

.hero__keyword {
    color: var(--color-orange);
}

.hero__description {
    font-size: clamp(1rem, 1vw, 1.125rem);
    color: rgba(255, 255, 255, 0.75);
    margin-bottom: var(--spacing-lg);
    line-height: 1.8;
    max-width: 640px;
}

/* Hero Stats */
.hero__stats {
    display: flex;
    justify-content: flex-start;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-lg) 0;
}

.hero__stat {
    text-align: center;
}

.hero__stat-number {
    font-size: 2.5rem;
    font-weight: 800;
    font-family: var(--font-heading);
    color: var(--color-navy);
    line-height: 1;
    margin-bottom: 0.5rem;
}

.hero__stat-label {
    font-size: 0.875rem;
    color: var(--color-text-light);
    font-weight: 500;
}

.hero__buttons {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-lg);
    justify-content: flex-start;
}

.hero__media {
    position: relative;
    display: flex;
    justify-content: flex-end;
}

.hero__split-right .hero__media {
    width: 100%;
    justify-content: center;
}

.hero__media-frame {
    position: relative;
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 30px 60px rgba(15, 39, 68, 0.18);
    clip-path: polygon(8% 0, 100% 0, 100% 100%, 0 100%);
    width: 100%;
    max-width: 640px;
    min-height: 420px;
}

.hero__media-frame::after {
    content: '';
    position: absolute;
    right: -20px;
    bottom: -20px;
    width: 140px;
    height: 140px;
    background: var(--color-orange);
    border-top-left-radius: 80px;
    opacity: 0.95;
}


.hero__media-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center right;
    transform: scale(1.05);
}

/* ============================================
   HERO SVG ILLUSTRATION
   ============================================ */
.hero__svg-container {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: min(820px, 100%);
    max-width: 580px;
    margin: 0 auto;
    padding: 1rem;
}

.hero__svg {
    width: 100%;
    height: auto;
    overflow: visible;
}


@media (min-width: 1700px) {
    .hero__split {
        grid-template-columns: 1fr 1fr;
    }

    .hero__split-left__inner {
        max-width: 820px;
    }

    .hero__buttons {
        gap: 1.25rem;
    }

    .hero__svg-container {
        max-width: 900px;
    }
}

/* Base layer transitions */
.hero__svg-layer {
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s ease;
}

.hero__svg-icon {
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Background layer - subtle pulse animation */
.hero__svg-layer--bg circle {
    animation: bgPulse 4s ease-in-out infinite;
}

.hero__svg-layer--bg circle:nth-child(2) {
    animation-delay: 1s;
}

.hero__svg-layer--bg circle:nth-child(3) {
    animation-delay: 2s;
}

@keyframes bgPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.1); opacity: 0.7; }
}

/* Connection lines animation */
.hero__svg-layer--lines path {
    stroke-dasharray: 5, 5;
    animation: dashMove 2s linear infinite;
}

@keyframes dashMove {
    0% { stroke-dashoffset: 0; }
    100% { stroke-dashoffset: 20; }
}

/* Floating dots subtle movement */
.hero__svg-layer--dots circle {
    animation: dotFloat 3s ease-in-out infinite;
}

.hero__svg-layer--dots circle:nth-child(odd) {
    animation-direction: reverse;
    animation-delay: 0.5s;
}

@keyframes dotFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}

/* ============================================
   HERO SVG HOVER ANIMATIONS
   ============================================ */

/* Browser window - lift and slight rotation on hover */
.hero__svg-container:hover .hero__svg-layer--browser {
    transform: translateY(-8px) rotate(-1deg);
}

/* Code card - lift and move slightly right */
.hero__svg-container:hover .hero__svg-layer--code {
    transform: translate(10px, -12px) rotate(2deg);
}

/* Design card - lift and move slightly left */
.hero__svg-container:hover .hero__svg-layer--design {
    transform: translate(-8px, -10px) rotate(-2deg);
}

/* Icons - bounce and scale on hover */
.hero__svg-container:hover .hero__svg-icon--responsive {
    transform: translateY(-15px) scale(1.15);
}

.hero__svg-container:hover .hero__svg-icon--chart {
    transform: translateY(-12px) scale(1.12);
    transition-delay: 0.05s;
}

.hero__svg-container:hover .hero__svg-icon--rocket {
    transform: translateY(-18px) scale(1.1) rotate(-10deg);
    transition-delay: 0.1s;
}

/* Connection lines - increase opacity on hover */
.hero__svg-container:hover .hero__svg-layer--lines {
    opacity: 0.8;
}

.hero__svg-container:hover .hero__svg-layer--lines path {
    animation-duration: 1s;
}

/* Background circles - expand on hover */
.hero__svg-container:hover .hero__svg-layer--bg {
    transform: scale(1.05);
}

/* Dots - scatter effect on hover */
.hero__svg-container:hover .hero__svg-layer--dots circle:nth-child(1) {
    transform: translate(-5px, -8px);
}

.hero__svg-container:hover .hero__svg-layer--dots circle:nth-child(2) {
    transform: translate(8px, -5px);
}

.hero__svg-container:hover .hero__svg-layer--dots circle:nth-child(3) {
    transform: translate(5px, 10px);
}

.hero__svg-container:hover .hero__svg-layer--dots circle:nth-child(4) {
    transform: translate(-8px, 5px);
}

.hero__svg-container:hover .hero__svg-layer--dots circle:nth-child(5) {
    transform: translate(3px, -10px);
}

/* Responsive adjustments for SVG */
@media (max-width: 768px) {
    .hero__svg-container {
        max-width: 420px;
        margin: 0 auto;
    }
}

@media (max-width: 480px) {
    .hero__svg-container {
        max-width: 320px;
        padding: 0.5rem;
    }

    /* Reduce animation intensity on mobile */
    .hero__svg-container:hover .hero__svg-layer--browser {
        transform: translateY(-4px) rotate(-0.5deg);
    }

    .hero__svg-container:hover .hero__svg-layer--code {
        transform: translate(5px, -6px) rotate(1deg);
    }

    .hero__svg-container:hover .hero__svg-layer--design {
        transform: translate(-4px, -5px) rotate(-1deg);
    }
}

.btn--glass {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.btn--glass svg {
    transition: transform var(--transition-fast);
}

.btn--glass:hover svg {
    transform: translateX(4px);
}


/* ============================================
   PROJECTS SECTION
   ============================================ */
.projects {
    background: var(--color-bg-light);
    position: relative;
    overflow: hidden;
}

.projects::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    height: 300px;
    background: radial-gradient(ellipse at center, rgba(30, 58, 95, 0.06) 0%, transparent 70%);
    pointer-events: none;
}

.section__badge {
    display: inline-block;
    background: none;
    border: none;
    border-top: 2px solid var(--color-orange);
    border-radius: 0;
    padding: 0.45rem 0 0;
    color: var(--color-text-light);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: var(--spacing-md);
    box-shadow: none;
}

.projects__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(350px, 100%), 1fr));
    gap: var(--spacing-xl);
    position: relative;
}

.project-card {
    position: relative;
    background: var(--color-white);
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border: 1px solid rgba(30, 58, 95, 0.1);
}

.project-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--solid-navy);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.project-card:hover::before {
    transform: scaleX(1);
}

.project-card:hover {
    transform: translateY(-12px);
    box-shadow: 0 20px 60px rgba(30, 58, 95, 0.15);
    border-color: rgba(30, 58, 95, 0.3);
}

/* Project Card Glow Effect */
.project-card__glow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, rgba(30, 58, 95, 0.1) 0%, transparent 70%);
    opacity: 0;
    transition: opacity 0.6s ease;
    pointer-events: none;
    z-index: 0;
}

.project-card:hover .project-card__glow {
    opacity: 1;
}

/* Featured Badge */
.project-card__featured-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: #fbbf24;
    color: var(--color-white);
    padding: 0.4rem 1rem;
    border-radius: var(--radius-xl);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 15px rgba(251, 191, 36, 0.4);
    z-index: 10;
    animation: featured-pulse 2s infinite;
}

@keyframes featured-pulse {
    0%, 100% {
        box-shadow: 0 4px 15px rgba(251, 191, 36, 0.4);
    }
    50% {
        box-shadow: 0 6px 25px rgba(251, 191, 36, 0.6);
    }
}

/* Browser Mockup */
.browser-mockup {
    background: var(--color-white);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    overflow: hidden;
    box-shadow: 0 0 0 1px var(--color-border);
    position: relative;
    z-index: 1;
}

.browser-mockup__header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.875rem 1rem;
    background: #f8fafc;
    border-bottom: 1px solid var(--color-border);
}

.browser-mockup__dots {
    display: flex;
    gap: 0.5rem;
}

.browser-mockup__dots span {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--color-border);
    transition: transform 0.2s ease;
}

.project-card:hover .browser-mockup__dots span {
    transform: scale(1.1);
}

.browser-mockup__dots span:nth-child(1) {
    background: #ff5f57;
}

.browser-mockup__dots span:nth-child(2) {
    background: #ffbd2e;
}

.browser-mockup__dots span:nth-child(3) {
    background: #28ca42;
}

.browser-mockup__url {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: var(--color-white);
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    color: var(--color-text-light);
    font-size: 0.875rem;
}

.browser-mockup__url svg {
    color: var(--color-text-lighter);
    flex-shrink: 0;
}

.browser-mockup__content {
    position: relative;
    width: 100%;
    aspect-ratio: var(--mockup-width) / var(--mockup-height);
    overflow: hidden;
    background: var(--color-bg-light);
    --mockup-width: 1440;
    --mockup-height: 900;
    --mockup-scale: 0.25;
}

.browser-mockup__content iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(var(--mockup-width) * 1px);
    height: calc(var(--mockup-height) * 1px);
    border: none;
    pointer-events: none;
    transform: scale(var(--mockup-scale));
    transform-origin: 0 0;
}

.browser-mockup__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(30, 41, 59, 0.95);
    opacity: 0;
    transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(8px);
}

.browser-mockup__overlay-content {
    transform: translateY(20px);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.project-card:hover .browser-mockup__overlay {
    opacity: 1;
}

.project-card:hover .browser-mockup__overlay-content {
    transform: translateY(0);
}

.browser-mockup__overlay .btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    background: var(--color-white);
    color: var(--color-orange);
    border-radius: var(--radius-lg);
    font-weight: 600;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    transition: all 0.3s ease;
}

.browser-mockup__overlay .btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.4);
    background: var(--color-orange);
    color: var(--color-white);
}

.browser-mockup__overlay .btn svg {
    transition: transform 0.3s ease;
}

.browser-mockup__overlay .btn:hover svg {
    transform: translateX(3px);
}

.project-card__info {
    padding: 2rem 1.75rem;
    position: relative;
    z-index: 1;
}

.project-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
    gap: 1rem;
}

.project-card__title {
    font-size: 1.35rem;
    color: var(--color-navy);
    margin: 0;
    line-height: 1.3;
    flex: 1;
}

.project-card__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(249, 115, 22, 0.1);
    border-radius: var(--radius-lg);
    color: var(--color-orange);
    transition: all 0.3s ease;
}

.project-card:hover .project-card__icon {
    background: var(--solid-orange);
    color: var(--color-white);
    transform: rotate(5deg) scale(1.05);
}

.project-card__desc {
    color: var(--color-text-light);
    margin-bottom: 1.25rem;
    line-height: 1.6;
}

.project-card__tags {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.tag {
    display: inline-block;
    padding: 0.4rem 1rem;
    background: var(--color-bg-lighter);
    color: var(--color-navy);
    font-size: 0.8125rem;
    border-radius: 3px;
    font-weight: 500;
    border: 1px solid transparent;
    transition: all 0.3s ease;
}

.tag--primary {
    background: rgba(249, 115, 22, 0.1);
    color: var(--color-orange);
    border-color: rgba(249, 115, 22, 0.2);
}

.tag--secondary {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
    border-color: rgba(59, 130, 246, 0.2);
}

.project-card:hover .tag {
    transform: translateY(-2px);
}

.project-card:hover .tag--primary {
    background: var(--solid-orange);
    color: var(--color-white);
    border-color: transparent;
}

.project-card:hover .tag--secondary {
    background: #3b82f6;
    color: var(--color-white);
    border-color: transparent;
}

/* ============================================
   FEATURES SECTION
   ============================================ */
.features__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: var(--spacing-lg);
}

.features__stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    align-items: center;
    margin: 0 auto var(--spacing-xl);
    padding: var(--spacing-md);
    background: linear-gradient(135deg, var(--color-navy-dark) 0%, var(--color-navy) 60%, var(--color-navy-light) 100%);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 14px 32px rgba(15, 39, 68, 0.2);
}

.features__stat {
    text-align: center;
    padding: 0.85rem 0.75rem;
    border-right: 1px solid rgba(255, 255, 255, 0.14);
}

.features__stat:last-child {
    border-right: none;
}

.features__stat-number {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 800;
    font-family: var(--font-heading);
    color: #ff9e42;
    line-height: 1;
    margin-bottom: 0.5rem;
}

.features__stat-label {
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.86);
    font-weight: 500;
}


@media (max-width: 768px) {
    .features__stats {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .features__stat {
        border-right: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    }

    .features__stat:last-child {
        border-bottom: none;
    }
}

.feature-card {
    position: relative;
    padding: 3.5rem var(--spacing-lg) var(--spacing-lg);
    text-align: left;
    background: var(--color-white);
    border-radius: 1.25rem;
    border: 1px solid rgba(30, 58, 95, 0.08);
    box-shadow: 0 12px 30px rgba(15, 39, 68, 0.08);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);
}

.feature-card__icon {
    position: absolute;
    top: -26px;
    left: 28px;
    width: 58px;
    height: 58px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-orange);
    background: var(--color-white);
    border: 1px solid rgba(30, 58, 95, 0.08);
    border-radius: var(--radius-full);
    box-shadow: 0 10px 20px rgba(15, 39, 68, 0.12);
    transition: background var(--transition-normal), color var(--transition-normal), border-color var(--transition-normal), transform var(--transition-normal);
}

.feature-card__title {
    color: var(--color-navy);
    margin-bottom: var(--spacing-sm);
}

.feature-card__text {
    color: var(--color-text-light);
    margin: 0;
}

.feature-card::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    border: 1px solid rgba(249, 115, 22, 0.18);
    opacity: 0;
    transition: opacity var(--transition-normal);
    pointer-events: none;
}

.feature-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(15, 39, 68, 0.14);
    border-color: rgba(249, 115, 22, 0.25);
}

.feature-card:hover::after {
    opacity: 1;
}

.feature-card:hover .feature-card__icon {
    background: var(--color-orange);
    color: var(--color-white);
    border-color: transparent;
    transform: translateY(-2px);
}

/* Glass Card Effect */
.glass-card {
    background: rgba(255, 255, 255, 0.6);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
}

/* ============================================
   SERVICES SECTION
   ============================================ */
.services {
    background: linear-gradient(120deg, rgba(248, 250, 252, 1) 0%, rgba(241, 245, 249, 0.9) 60%, rgba(255, 247, 237, 0.85) 100%);
    position: relative;
    overflow: hidden;
}

.services__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: var(--spacing-xl);
}

.services__standard {
    margin: 0 auto var(--spacing-xl);
    max-width: 700px;
    background: var(--color-white);
    border: 2px solid var(--color-navy);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.services__standard-title {
    color: var(--color-navy);
    font-weight: 700;
    font-size: 1.125rem;
    margin: 0 0 var(--spacing-md);
    text-align: center;
    font-family: var(--font-heading);
}

.services__standard-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.services__standard-list li {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--color-navy);
    font-weight: 500;
    padding: 0.625rem 1rem;
    background: rgba(255, 255, 255, 0.7);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
}

.services__standard-list li::before {
    content: '✓';
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background: var(--solid-orange);
    color: var(--color-white);
    border-radius: var(--radius-sm);
    font-weight: 700;
    font-size: 0.875rem;
    flex-shrink: 0;
}

/* Green checkmarks are kept as accent */

.service-card {
    position: relative;
    background: var(--color-white);
    padding: 3.5rem var(--spacing-lg) var(--spacing-lg);
    border-radius: 1.25rem;
    box-shadow: 0 12px 30px rgba(15, 39, 68, 0.08);
    border: 1px solid rgba(30, 58, 95, 0.08);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);
}

.service-card__icon {
    position: absolute;
    top: -26px;
    left: 28px;
    width: 58px;
    height: 58px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-orange);
    background: var(--color-white);
    border: 1px solid rgba(30, 58, 95, 0.08);
    border-radius: var(--radius-full);
    box-shadow: 0 10px 20px rgba(15, 39, 68, 0.12);
    transition: background var(--transition-normal), color var(--transition-normal), border-color var(--transition-normal), transform var(--transition-normal);
}

.service-card__title {
    color: var(--color-navy);
    margin-bottom: var(--spacing-sm);
}

.service-card__text {
    color: var(--color-text-light);
    margin: 0;
}

.service-card--link {
    text-decoration: none;
    color: inherit;
    display: block;
}

.service-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-top: 1rem;
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--color-orange);
    transition: gap var(--transition-fast);
}

.service-card--link:hover .service-card__link {
    gap: 0.7rem;
}

.service-tech-stack {
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(15, 39, 68, 0.14);
    border-color: rgba(249, 115, 22, 0.25);
}

.service-card:hover .service-card__icon {
    background: var(--color-orange);
    color: var(--color-white);
    border-color: transparent;
    transform: translateY(-2px);
}

/* ============================================
   ENHANCED PRICING SECTION
   ============================================ */
.pricing {
    background: linear-gradient(120deg, rgba(248, 250, 252, 1) 0%, rgba(241, 245, 249, 0.92) 55%, rgba(255, 247, 237, 0.85) 100%);
    position: relative;
    overflow: hidden;
}

.pricing__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr));
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.pricing-card {
    position: relative;
    background: var(--color-white);
    border-radius: 1.25rem;
    padding: 3.5rem var(--spacing-lg) var(--spacing-lg);
    box-shadow: 0 14px 32px rgba(15, 39, 68, 0.1);
    border: 1px solid rgba(30, 58, 95, 0.08);
    transition: all var(--transition-normal);
    display: flex;
    flex-direction: column;
}

.pricing-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 22px 44px rgba(15, 39, 68, 0.16);
    border-color: var(--color-orange);
}

.pricing-card__icon {
    position: absolute;
    top: -26px;
    left: 28px;
    width: 58px;
    height: 58px;
    border-radius: var(--radius-full);
    background: var(--color-white);
    border: 1px solid rgba(30, 58, 95, 0.08);
    box-shadow: 0 10px 20px rgba(15, 39, 68, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-orange);
    transition: background var(--transition-normal), color var(--transition-normal), border-color var(--transition-normal), transform var(--transition-normal);
}

.pricing-card:hover .pricing-card__icon {
    background: var(--color-orange);
    color: var(--color-white);
    border-color: transparent;
    transform: translateY(-2px);
}

/* Featured Pricing Card */
.pricing-card--featured {
    background: var(--solid-navy);
    border-color: var(--color-navy);
    transform: scale(1.05);
    z-index: 1;
}

.pricing-card--featured:hover {
    transform: scale(1.05) translateY(-8px);
}

.pricing-card--featured .pricing-card__title,
.pricing-card--featured .pricing-card__subtitle,
.pricing-card--featured .pricing-card__currency,
.pricing-card--featured .pricing-card__amount,
.pricing-card--featured .pricing-card__period,
.pricing-card--featured .pricing-card__features li span {
    color: var(--color-white);
}

.pricing-card--featured .pricing-card__features li svg {
    color: var(--color-orange-light);
}

.pricing-card--featured .pricing-card__note {
    color: rgba(255, 255, 255, 0.8);
}

.pricing-card--featured .pricing-card__note svg {
    color: var(--color-orange-light);
}

.pricing-card--featured .btn--primary {
    background: var(--solid-orange);
    color: var(--color-white);
}

.pricing-card--featured .btn--primary:hover {
    background: var(--color-orange-dark);
}

/* Pricing Card Glow Effect */
.pricing-card__glow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 120%;
    height: 120%;
    background: radial-gradient(circle, rgba(249, 115, 22, 0.2) 0%, transparent 70%);
    z-index: -1;
    opacity: 0;
    transition: opacity var(--transition-slow);
}

.pricing-card--featured:hover .pricing-card__glow {
    opacity: 1;
}

.pricing-card__badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--solid-orange);
    color: var(--color-white);
    padding: 0.4rem 1.25rem;
    border-radius: var(--radius-xl);
    font-size: 0.8rem;
    font-weight: 700;
    box-shadow: var(--shadow-md);
    white-space: nowrap;
}

.pricing-card__badge--featured {
    background: #fbbf24;
}

.pricing-card__header {
    text-align: center;
    margin-bottom: var(--spacing-md);
    padding-top: var(--spacing-md);
}

.pricing-card__title {
    font-size: 1.75rem;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.pricing-card__subtitle {
    color: var(--color-text-light);
    font-size: 0.875rem;
}

.pricing-card__price {
    text-align: center;
    margin-bottom: var(--spacing-lg);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 0.25rem;
}

.pricing-card__currency {
    font-size: 1.5rem;
    color: var(--color-navy);
    font-weight: 700;
    margin-top: 0.5rem;
}

.pricing-card__amount {
    font-size: 3.5rem;
    font-family: var(--font-heading);
    font-weight: 800;
    color: var(--color-navy);
    line-height: 1;
}

.pricing-card__period {
    font-size: 1rem;
    color: var(--color-text-light);
    align-self: flex-end;
    margin-bottom: 0.5rem;
}

.pricing-card__features {
    flex: 1;
    margin-bottom: var(--spacing-lg);
}

.pricing-card__features li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--color-border);
}

.pricing-card--featured .pricing-card__features li {
    border-bottom-color: rgba(255, 255, 255, 0.1);
}

.pricing-card__features li:last-child {
    border-bottom: none;
}

.pricing-card__features li svg {
    flex-shrink: 0;
    color: var(--color-orange);
    margin-top: 2px;
}

.pricing-card__features li span {
    color: var(--color-text-dark);
    line-height: 1.5;
}

.pricing-card__note {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: var(--spacing-md);
    padding: 0.75rem;
    background: var(--color-bg-light);
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    color: var(--color-text-light);
}

.pricing-card--featured .pricing-card__note {
    background: rgba(255, 255, 255, 0.1);
}

.pricing-card__note svg {
    flex-shrink: 0;
    color: var(--color-orange);
}

.pricing__info {
    max-width: 800px;
    margin: 0 auto;
}

.pricing__info-card {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
    padding: var(--spacing-lg);
    background: var(--color-white);
    color: var(--color-text-dark);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    border: 1px solid rgba(30, 58, 95, 0.08);
}

.pricing__info-card svg {
    flex-shrink: 0;
    color: var(--color-orange);
}

.pricing__info-card h4 {
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.pricing__info-card p {
    margin: 0;
    color: var(--color-text-light);
}

/* ============================================
   INDUSTRIES SECTION
   ============================================ */
.industries {
    background: var(--color-bg-light);
    position: relative;
    overflow: hidden;
}

.industries__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    gap: var(--spacing-md);
    padding-top: 1.5rem;
    margin-top: 0.5rem;
}

.industry-card {
    position: relative;
    background: var(--color-white);
    padding: 3rem var(--spacing-md) var(--spacing-md);
    border-radius: 1.125rem;
    box-shadow: 0 10px 24px rgba(15, 39, 68, 0.08);
    text-align: left;
    border: 1px solid rgba(30, 58, 95, 0.08);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);
}

.industry-card__icon {
    position: absolute;
    top: -20px;
    left: 20px;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-orange);
    background: var(--color-white);
    border-radius: var(--radius-full);
    border: 1px solid rgba(30, 58, 95, 0.08);
    box-shadow: 0 8px 18px rgba(15, 39, 68, 0.12);
    transition: background var(--transition-normal), color var(--transition-normal), border-color var(--transition-normal), transform var(--transition-normal);
}

.industry-card__title {
    color: var(--color-navy);
    font-size: 1.125rem;
    margin-bottom: var(--spacing-xs);
}

.industry-card__text {
    color: var(--color-text-light);
    font-size: 0.875rem;
    margin: 0;
}

.industry-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 18px 34px rgba(15, 39, 68, 0.14);
    border-color: rgba(249, 115, 22, 0.25);
}

.industry-card:hover .industry-card__icon {
    background: var(--color-orange);
    color: var(--color-white);
    border-color: transparent;
    transform: translateY(-2px);
}

/* ============================================
   CONTACT SECTION
   ============================================ */
.contact {
    background: var(--color-bg-light);
    position: relative;
    overflow: hidden;
}

.contact__wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    align-items: start;
}

.contact__form-container {
    background: var(--color-white);
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
}

.contact__form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.form__group {
    display: flex;
    flex-direction: column;
}

.form__label {
    font-weight: 500;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
}

.form__input,
.form__select,
.form__textarea {
    padding: 0.875rem 1rem;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 1rem;
    transition: all var(--transition-fast);
}

.form__input:focus,
.form__select:focus,
.form__textarea:focus {
    outline: none;
    border-color: var(--color-orange);
    box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.1);
}

.form__textarea {
    resize: vertical;
    min-height: 120px;
}

.form__submit {
    margin-top: var(--spacing-sm);
    transition: transform 0.6s;
    transform-style: preserve-3d;
}

.form__submit.flip {
    animation: flipButton 0.6s ease-in-out;
}

@keyframes flipButton {
    0% {
        transform: rotateY(0deg);
    }
    50% {
        transform: rotateY(180deg);
    }
    100% {
        transform: rotateY(360deg);
    }
}

.form__success {
    display: none;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: var(--color-bg-light);
    border-radius: var(--radius-lg);
    text-align: center;
    margin-top: var(--spacing-md);
}

.form__success.show {
    display: flex;
}

.form__success-icon {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--solid-orange);
    color: var(--color-white);
    border-radius: var(--radius-sm);
    font-size: 2rem;
}

.form__success h3 {
    color: var(--color-navy);
    margin: 0;
}

.form__success p {
    color: var(--color-text-light);
    margin: 0;
}

/* Contact FAQ Sidebar */
.contact__faq-container {
    background: var(--color-white);
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    height: 100%;
}

.contact__faq-title {
    font-size: 1.5rem;
    color: var(--color-navy);
    margin-bottom: var(--spacing-md);
    font-family: var(--font-heading);
}

.contact__faq-list {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.contact__faq-link {
    color: var(--color-orange);
    font-weight: 600;
    font-size: 0.9375rem;
    text-align: center;
    padding: var(--spacing-sm);
    transition: color var(--transition-fast);
}

.contact__faq-link:hover {
    color: var(--color-orange-dark);
}

/* Compact FAQ Items */
.faq-item-compact {
    background: var(--color-bg-light);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all var(--transition-normal);
}

.faq-item-compact:hover {
    box-shadow: var(--shadow-sm);
}

.faq-item-compact__question {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.875rem 1rem;
    text-align: left;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-navy);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.faq-item-compact__question:hover {
    color: var(--color-orange);
}

.faq-item-compact__icon {
    font-size: 1.25rem;
    font-weight: 300;
    color: var(--color-orange);
    transition: transform var(--transition-normal);
    flex-shrink: 0;
    margin-left: 0.5rem;
}

.faq-item-compact.active .faq-item-compact__icon {
    transform: rotate(45deg);
}

.faq-item-compact__answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-slow);
}

.faq-item-compact.active .faq-item-compact__answer {
    max-height: 300px;
}

.faq-item-compact__answer p {
    padding: 0 1rem 0.875rem;
    color: var(--color-text-light);
    line-height: 1.6;
    margin: 0;
    font-size: 0.875rem;
}

/* ============================================
   BUTTONS
   ============================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.875rem 2rem;
    border-radius: var(--radius-lg);
    font-weight: 600;
    font-size: 1rem;
    transition: all var(--transition-normal);
    cursor: pointer;
    text-align: center;
    white-space: nowrap;
}

.btn--primary {
    background: var(--solid-navy);
    color: var(--color-white);
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.btn--primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: -150%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.4) 50%, transparent 100%);
    transition: left 0.6s ease;
    pointer-events: none;
}

.btn--primary:hover::before {
    left: 150%;
}

.btn--primary:hover {
    transform: translateY(-2px);
}

.btn--glass {
    background: rgba(30, 58, 95, 0.08);
    backdrop-filter: blur(10px);
    color: var(--color-navy);
    border: 1px solid rgba(30, 58, 95, 0.2);
}

.btn--glass:hover {
    background: rgba(30, 58, 95, 0.14);
    transform: translateY(-2px);
}

/* Glass variant for dark backgrounds */
.btn--glass-light {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: var(--color-white);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.btn--glass-light:hover {
    background: rgba(255, 255, 255, 0.18);
    transform: translateY(-2px);
    color: var(--color-white);
}

.btn--whatsapp {
    background-color: #25D366;
    color: #fff;
    border: none;
}

.btn--whatsapp:hover {
    background-color: #128C7E;
    color: #fff;
    transform: translateY(-2px);
}

.btn--large {
    padding: 1rem 2.5rem;
    font-size: 1.125rem;
    grid-column: 1 / -1;
}

.btn--full {
    width: 100%;
}

.btn--small {
    padding: 0.5rem 1.25rem;
    font-size: 0.875rem;
}

/* btn--pulse class kept for compatibility, no glow animation */

/* ============================================
   FOOTER
   ============================================ */
.footer {
    background: var(--color-navy-dark);
    color: var(--color-white);
    padding: var(--spacing-xl) 0 var(--spacing-md);
}

.footer__content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.footer__logo-img {
    height: 40px;
    width: auto;
}

.footer__tagline {
    color: rgba(255, 255, 255, 0.7);
    margin-top: 0.5rem;
    margin-bottom: 0;
}

.footer__social {
    display: flex;
    gap: var(--spacing-md);
}

.footer__social-link {
    color: rgba(255, 255, 255, 0.7);
    transition: color var(--transition-fast);
}

.footer__social-link:hover {
    color: var(--color-orange);
}

.footer__bottom {
    text-align: center;
}

.footer__copyright {
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.875rem;
    margin: 0;
}

/* Footer Grid Layout with Backlinks */
.footer__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
    align-items: start;
}

.footer__links {
    display: flex;
    flex-direction: column;
}

.footer__heading {
    color: var(--color-white);
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.footer__nav {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.footer__nav li a,
.footer__nav li span {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.9rem;
    transition: color var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.footer__nav li a:hover {
    color: var(--color-orange);
}

.footer__contact li a,
.footer__contact li span {
    font-size: 0.85rem;
}

.footer__credits {
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.8rem;
    margin-top: 0.5rem;
}

.footer__credits a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: underline;
}

.footer__credits a:hover {
    color: var(--color-orange);
}

/* Footer Responsive */
@media (max-width: 992px) {
    .footer__grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-lg);
    }

    .footer__brand {
        grid-column: span 2;
    }
}

@media (max-width: 576px) {
    .footer__grid {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .footer__brand {
        grid-column: span 1;
    }

    .footer__social {
        justify-content: center;
    }

    .footer__nav {
        align-items: center;
    }
}

/* ============================================
   SCROLL TO TOP BUTTON - Portrait Text Design
   ============================================ */
.scroll-top {
    position: fixed;
    bottom: 7rem;
    right: 2rem;
    background: transparent;
    color: var(--color-navy);
    border: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding: 0;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-normal);
    z-index: var(--z-fixed);
    cursor: pointer;
    overflow: visible;
}

.scroll-top__text {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    transition: all var(--transition-normal);
    color: var(--color-navy);
}

.scroll-top__arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.75rem;
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    transition: all 0.4s ease;
}

.scroll-top__arrow iconify-icon {
    font-size: 2.5rem;
    color: var(--color-navy);
}

.scroll-top.show {
    opacity: 1;
    visibility: visible;
}

.scroll-top:hover .scroll-top__text {
    color: var(--color-navy);
}

.scroll-top:hover .scroll-top__arrow {
    opacity: 1;
    max-height: 60px;
}

.scroll-top:hover .scroll-top__arrow iconify-icon {
    color: var(--color-navy);
}

/* White variant when over dark footer */
.scroll-top.over-footer .scroll-top__text {
    color: var(--color-white);
}

.scroll-top.over-footer .scroll-top__arrow iconify-icon {
    color: var(--color-white);
}

.scroll-top.over-footer:hover .scroll-top__text,
.scroll-top.over-footer:hover .scroll-top__arrow iconify-icon {
    color: var(--color-white);
}

/* Loading state for scroll-to-top button */
.scroll-top.scrolling {
    pointer-events: none;
}

.scroll-top.scrolling .scroll-top__text,
.scroll-top.scrolling .scroll-top__arrow {
    display: none;
}

.scroll-top.scrolling::after {
    content: '';
    width: 24px;
    height: 24px;
    border: 3px solid rgba(30, 58, 95, 0.3);
    border-top-color: var(--color-navy);
    border-radius: 50%;
    animation: scroll-top-spin 0.6s linear infinite;
}

@keyframes scroll-top-spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

/* ============================================
   WHATSAPP WIDGET
   ============================================ */
.whatsapp-float {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 2rem;
    left: 2rem;
    background-color: #25D366;
    color: #fff;
    border-radius: 50%;
    text-align: center;
    font-size: 32px;
    z-index: var(--z-fixed);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-normal);
}

.whatsapp-float:hover {
    background-color: #128C7E;
    transform: scale(1.1);
}

.whatsapp-float iconify-icon {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ============================================
   REVEAL ON SCROLL ANIMATION - Slide from Left
   ============================================ */
.reveal-on-scroll {
    opacity: 0;
    transform: translateX(-60px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.reveal-on-scroll.revealed {
    opacity: 1;
    transform: translateX(0);
}

/* Stagger animation for cards in a grid */
.reveal-on-scroll:nth-child(2) {
    transition-delay: 0.1s;
}

.reveal-on-scroll:nth-child(3) {
    transition-delay: 0.2s;
}

.reveal-on-scroll:nth-child(4) {
    transition-delay: 0.3s;
}

.reveal-on-scroll:nth-child(5) {
    transition-delay: 0.4s;
}

.reveal-on-scroll:nth-child(6) {
    transition-delay: 0.5s;
}

/* ============================================
   COOKIE CONSENT BANNER
   ============================================ */
.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--color-navy-dark);
    color: var(--color-white);
    padding: 1.25rem 1.5rem;
    z-index: var(--z-modal);
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.cookie-banner.show {
    transform: translateY(0);
}

.cookie-banner__content {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    flex-wrap: wrap;
}

.cookie-banner__text {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.6;
    flex: 1;
    min-width: 280px;
}

.cookie-banner__actions {
    display: flex;
    gap: 0.75rem;
    flex-shrink: 0;
}

.cookie-banner__btn {
    padding: 0.625rem 1.5rem;
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.cookie-banner__btn--accept {
    background: var(--solid-orange);
    color: var(--color-white);
}

.cookie-banner__btn--accept:hover {
    background: var(--color-orange-dark);
}

.cookie-banner__btn--decline {
    background: transparent;
    color: var(--color-white);
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.cookie-banner__btn--decline:hover {
    background: rgba(255, 255, 255, 0.1);
}

.cookie-banner__btn--manage {
    background: transparent;
    color: var(--color-white);
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.cookie-banner__btn--manage:hover {
    background: rgba(255, 255, 255, 0.1);
}

@media (max-width: 600px) {
    .cookie-banner__content {
        flex-direction: column;
        text-align: center;
    }

    .cookie-banner__actions {
        width: 100%;
        justify-content: center;
    }

    .cookie-banner__btn {
        flex: 1;
        max-width: 150px;
    }
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

/* Tablets */
@media (max-width: 768px) {
    :root {
        --spacing-xl: 3rem;
        --spacing-2xl: 4rem;
    }

    /* Prevent horizontal overflow on mobile */
    * {
        max-width: 100%;
    }

    html,
    body {
        width: 100%;
        max-width: 100%;
    }

    body {
        padding-left: var(--safe-area-left);
        padding-right: var(--safe-area-right);
        padding-bottom: var(--safe-area-bottom);
    }

    p,
    li,
    .section__subtitle,
    .hero__description,
    .preview-card__text,
    .service-card__description,
    .pricing-card__description {
        overflow-wrap: anywhere;
        word-break: break-word;
        hyphens: auto;
    }

    .container {
        padding: 0 1rem;
    }

    .section {
        overflow-x: hidden;
    }

    .nav__menu {
        position: fixed;
        top: calc(80px + var(--safe-area-top));
        left: -100%;
        width: calc(100% - var(--safe-area-left) - var(--safe-area-right));
        background: rgba(255, 255, 255, 0.98);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
        padding: 1.5rem;
        box-shadow: var(--shadow-lg);
        transition: left var(--transition-normal);
        z-index: var(--z-dropdown);
    }

    .nav__menu.show {
        left: 0;
    }

    /* Mobile menu links always dark colored (exclude button-style links) */
    .header:not(.scrolled) .nav__menu .nav__link:not(.nav__link--btn):not(.nav__link--highlight) {
        color: var(--color-navy);
    }

    .header:not(.scrolled) .nav__menu .nav__link:not(.nav__link--btn):not(.nav__link--highlight):hover,
    .header:not(.scrolled) .nav__menu .nav__link:not(.nav__link--btn):not(.nav__link--highlight).active {
        color: var(--color-orange);
    }

    .nav__list {
        flex-direction: column;
        gap: 1.5rem;
        align-items: stretch;
    }

    .nav__toggle {
        display: flex;
        min-width: 44px;
        min-height: 44px;
        justify-content: center;
        align-items: center;
    }

    .nav__link,
    .nav__dropdown-link,
    .btn,
    button,
    input,
    select,
    textarea {
        min-height: 44px;
    }

    .nav__link {
        display: flex;
        align-items: center;
    }

    input,
    select,
    textarea {
        font-size: 16px;
    }

    /* Mobile Dropdown Styles */
    .nav__dropdown {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
        box-shadow: none;
        background: var(--color-bg-light);
        margin-top: 0.5rem;
        border: none;
    }

    .nav__dropdown-link {
        display: flex;
        align-items: center;
        padding: 0.6rem 1.25rem 0.6rem 0.75rem;
        min-height: 44px;
    }

    .nav__item--dropdown .nav__dropdown {
        max-height: 0;
        overflow: hidden;
        transition: max-height var(--transition-normal);
    }

    .nav__item--dropdown.active .nav__dropdown {
        max-height: 200px;
    }

    .nav__link--btn {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    .nav__link--highlight {
        width: 100%;
        justify-content: center;
        padding: 0.75rem 1rem;
        margin: 0.5rem 0;
        font-size: 0.9rem;
    }

    .hero {
        min-height: 90vh;
        padding-top: 80px;
    }

    .hero__inner {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
        padding: 2rem 0;
    }

    .hero__content {
        max-width: 100%;
        padding: 0 1rem;
        text-align: left;
    }

    .hero__title {
        font-size: clamp(1.7rem, 7vw, 2.3rem);
        line-height: 1.2;
    }

    .hero__title-rotator {
        min-height: 3.3em;
    }

    .hero__title-rotating {
        white-space: normal;
        word-wrap: break-word;
        overflow-wrap: break-word;
    }

    .hero__description {
        font-size: 1rem;
    }

    .hero__buttons {
        justify-content: flex-start;
        flex-direction: row;
        gap: 1rem;
    }

    .hero__stats {
        gap: var(--spacing-md);
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .hero__stat {
        flex: 1;
        min-width: 120px;
    }

    .hero__stat-number {
        font-size: 1.75rem;
    }

    .hero__stat-label {
        font-size: 0.8125rem;
    }

    .hero__media {
        justify-content: center;
    }

    .hero__media-frame::after {
        right: -12px;
        bottom: -12px;
        width: 110px;
        height: 110px;
    }

    .contact__wrapper {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }

    .contact__form-container,
    .contact__faq-container {
        padding: var(--spacing-md);
    }

    .form__submit {
        width: 100%;
    }

    .footer__content {
        flex-direction: column;
        text-align: center;
    }

    .projects__grid {
        grid-template-columns: 1fr;
    }


    .whatsapp-float {
        width: 55px;
        height: 55px;
        bottom: 1.5rem;
        left: 1rem;
        font-size: 28px;
    }

    .whatsapp-float i {
        line-height: 55px;
    }

    .scroll-top {
        bottom: 6.5rem;
        right: 1rem;
    }

    .wa-widget {
        right: 1rem;
        bottom: 1rem;
    }
}

/* Mobile */
@media (max-width: 480px) {
    .hero {
        min-height: 86svh; /* Use small viewport height for mobile */
    }

    .hero__content {
        padding: 0 1rem;
    }

    .hero__title {
        font-size: clamp(1.35rem, 8.5vw, 1.9rem);
        margin-bottom: 1rem;
    }

    .hero__title-rotator {
        min-height: 4.2em;
    }

    .hero__description {
        font-size: 0.9375rem;
        margin-bottom: 1.5rem;
    }

    .hero__buttons {
        flex-direction: column;
        width: 100%;
        gap: 0.75rem;
    }

    .btn {
        width: 100%;
        padding: 0.75rem 1.5rem;
    }

    .hero__stats {
        flex-direction: row;
        gap: 1rem;
        flex-wrap: wrap;
    }

    .hero__stat {
        flex: 1;
        min-width: 100px;
    }

    .hero__stat-number {
        font-size: 1.5rem;
    }

    .hero__stat-label {
        font-size: 0.75rem;
    }

    .hero__badge {
        font-size: 0.75rem;
        padding: 0.4rem 1rem;
    }

    .pricing__grid {
        grid-template-columns: 1fr;
    }

    .pricing-card--featured {
        transform: scale(1);
    }

    .pricing-card--featured:hover {
        transform: scale(1) translateY(-8px);
    }

    .scroll-top {
        right: 1rem;
        bottom: 5.5rem;
        width: 48px;
        height: 48px;
        font-size: 1.25rem;
    }

    .wa-widget {
        right: 1rem;
        bottom: 1rem;
    }

    .whatsapp-float {
        width: 52px;
        height: 52px;
        bottom: 1.5rem;
        left: 1rem;
        font-size: 28px;
    }

    .whatsapp-float iconify-icon {
        width: 28px;
        height: 28px;
    }

    .whatsapp-float i {
        line-height: 52px;
    }

}

/* ============================================
   TILT.JS - 3D CARD EFFECTS
   ============================================ */
.feature-card,
.service-card,
.pricing-card,
.industry-card {
    transform-style: preserve-3d;
}

/* Glare effect positioning */
.feature-card .js-tilt-glare,
.service-card .js-tilt-glare,
.pricing-card .js-tilt-glare,
.industry-card .js-tilt-glare {
    border-radius: inherit;
}

/* Elevate inner content for 3D depth */
.feature-card__icon,
.feature-card__title,
.feature-card__text,
.service-card__icon,
.service-card__title,
.service-card__text,
.industry-card__icon,
.industry-card__title,
.industry-card__text {
    transform: translateZ(20px);
}

.pricing-card__header,
.pricing-card__price,
.pricing-card__features,
.pricing-card .btn {
    transform: translateZ(30px);
}

/* Disable tilt transforms on mobile (JS handles this, but CSS backup) */
@media (max-width: 768px) {
    .feature-card,
    .service-card,
    .pricing-card,
    .industry-card {
        transform: none !important;
    }
}

/* ============================================
   PAGE HERO SECTION
   ============================================ */
.page-hero {
    padding: 9rem 0 5rem;
    background: linear-gradient(135deg, var(--color-navy-dark) 0%, var(--color-navy) 100%);
    position: relative;
    overflow: hidden;
    width: 100%;
    border-left: none;
}

.page-hero::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    background: radial-gradient(circle at 70% 30%, rgba(249, 115, 22, 0.1) 0%, transparent 50%);
    pointer-events: none;
}

.page-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
    min-height: 35vh;
}

.page-hero__content {
    text-align: left;
    max-width: 500px;
    position: relative;
    z-index: 1;
}

.page-hero__badge {
    display: inline-block;
    background: none;
    border: none;
    border-top: 2px solid rgba(249, 115, 22, 0.8);
    border-radius: 0;
    padding: 0.45rem 0 0;
    color: rgba(255, 255, 255, 0.75);
    font-size: 0.78rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    box-shadow: none;
}

.page-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    font-weight: 800;
    color: white;
    margin-bottom: 1rem;
    line-height: 1.05;
    letter-spacing: -0.01em;
}

.page-hero__subtitle {
    font-size: 1.125rem;
    color: rgba(255, 255, 255, 0.8);
    line-height: 1.7;
    max-width: 600px;
    margin: 0;
}

.page-hero__buttons {
    margin-top: 2rem;
    display: flex;
    gap: 1rem;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.page-hero--web .page-hero__buttons {
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
}

.page-hero--web .page-hero__buttons .btn {
    padding-inline: 1.5rem;
}

@media (max-width: 992px) {
    .page-hero--web .page-hero__buttons {
        flex-wrap: wrap;
    }
}

.page-hero--automation {
    padding-bottom: 5rem;
}

/* Page Hero SVG Container */
.page-hero__svg-container {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.page-hero__svg {
    width: 100%;
    max-width: 400px;
    height: auto;
    overflow: visible;
}

/* Page SVG Layer Animations */
.page-svg__layer {
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s ease;
}

/* Background pulse animation */
.page-svg__layer--bg circle {
    animation: pageSvgPulse 4s ease-in-out infinite;
}

.page-svg__layer--bg circle:nth-child(2) {
    animation-delay: 1s;
}

.page-svg__layer--bg circle:nth-child(3) {
    animation-delay: 2s;
}

@keyframes pageSvgPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.08); opacity: 0.7; }
}

/* Main element subtle float animation */
.page-svg__layer--main {
    animation: pageSvgFloat 4s ease-in-out infinite;
}

@keyframes pageSvgFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

/* Card/badge float animations */
.page-svg__layer--card1,
.page-svg__layer--badge1,
.page-svg__layer--node1,
.page-svg__layer--bubble1 {
    animation: pageSvgFloatLeft 3.5s ease-in-out infinite;
}

.page-svg__layer--card2,
.page-svg__layer--badge2,
.page-svg__layer--node2,
.page-svg__layer--bubble2 {
    animation: pageSvgFloatRight 3.5s ease-in-out infinite;
    animation-delay: 0.5s;
}

.page-svg__layer--card3,
.page-svg__layer--badge3,
.page-svg__layer--node3,
.page-svg__layer--at {
    animation: pageSvgFloatLeft 3.8s ease-in-out infinite;
    animation-delay: 1s;
}

.page-svg__layer--card4,
.page-svg__layer--node4,
.page-svg__layer--icons {
    animation: pageSvgFloatRight 3.8s ease-in-out infinite;
    animation-delay: 1.5s;
}

@keyframes pageSvgFloatLeft {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(-5px, -8px); }
}

@keyframes pageSvgFloatRight {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(5px, -8px); }
}

/* Connection lines animated dash */
.page-svg__layer--lines path {
    animation: pageSvgDash 2s linear infinite;
}

@keyframes pageSvgDash {
    0% { stroke-dashoffset: 0; }
    100% { stroke-dashoffset: 20; }
}

/* Dots/particles subtle movement */
.page-svg__layer--dots circle,
.page-svg__layer--stars circle,
.page-svg__layer--particles circle {
    animation: pageSvgDotFloat 3s ease-in-out infinite;
}

.page-svg__layer--dots circle:nth-child(odd),
.page-svg__layer--particles circle:nth-child(odd) {
    animation-direction: reverse;
    animation-delay: 0.5s;
}

@keyframes pageSvgDotFloat {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-4px) scale(1.1); }
}

/* Arrows/gears pulse */
.page-svg__layer--arrows circle,
.page-svg__layer--gears circle {
    animation: pageSvgArrowPulse 2s ease-in-out infinite;
}

.page-svg__layer--arrows circle:nth-child(even),
.page-svg__layer--gears > circle:nth-child(even) {
    animation-delay: 0.3s;
}

@keyframes pageSvgArrowPulse {
    0%, 100% { transform: scale(1); opacity: 0.6; }
    50% { transform: scale(1.2); opacity: 1; }
}

/* Checkmark draw animation */
.page-svg__check {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    animation: pageSvgCheckDraw 1.5s ease-out forwards;
    animation-delay: 0.5s;
}

@keyframes pageSvgCheckDraw {
    to { stroke-dashoffset: 0; }
}

/* ============================================
   PAGE HERO SVG HOVER ANIMATIONS
   ============================================ */
.page-hero__svg-container:hover .page-svg__layer--main {
    transform: translateY(-12px) scale(1.02);
}

.page-hero__svg-container:hover .page-svg__layer--card1,
.page-hero__svg-container:hover .page-svg__layer--badge1,
.page-hero__svg-container:hover .page-svg__layer--node1,
.page-hero__svg-container:hover .page-svg__layer--bubble1 {
    transform: translate(-10px, -15px);
}

.page-hero__svg-container:hover .page-svg__layer--card2,
.page-hero__svg-container:hover .page-svg__layer--badge2,
.page-hero__svg-container:hover .page-svg__layer--node2,
.page-hero__svg-container:hover .page-svg__layer--bubble2 {
    transform: translate(10px, -15px);
}

.page-hero__svg-container:hover .page-svg__layer--card3,
.page-hero__svg-container:hover .page-svg__layer--badge3,
.page-hero__svg-container:hover .page-svg__layer--node3,
.page-hero__svg-container:hover .page-svg__layer--at {
    transform: translate(-8px, -12px);
}

.page-hero__svg-container:hover .page-svg__layer--card4,
.page-hero__svg-container:hover .page-svg__layer--node4,
.page-hero__svg-container:hover .page-svg__layer--icons {
    transform: translate(8px, -12px);
}

.page-hero__svg-container:hover .page-svg__layer--bg {
    transform: scale(1.05);
}

.page-hero__svg-container:hover .page-svg__layer--lines path {
    animation-duration: 1s;
    opacity: 0.8;
}

.page-hero__svg-container:hover .page-svg__layer--arrows circle {
    animation-duration: 0.8s;
}

@media (max-width: 768px) {
    .page-hero {
        padding: 7rem 0 3rem;
    }

    .page-hero__inner {
        grid-template-columns: 1fr;
        gap: 2rem;
        text-align: center;
    }

    .page-hero__content {
        text-align: center;
        max-width: 100%;
    }

    .page-hero__buttons {
        justify-content: center;
    }


    .page-hero__subtitle {
        font-size: 1rem;
        margin: 0 auto;
    }

    .page-hero__svg-container {
        order: -1;
    }

    .page-hero__svg {
        max-width: 320px;
    }

    /* Reduce animation intensity on mobile */
    .page-hero__svg-container:hover .page-svg__layer--main {
        transform: translateY(-6px) scale(1.01);
    }

    .page-hero__svg-container:hover .page-svg__layer--card1,
    .page-hero__svg-container:hover .page-svg__layer--badge1,
    .page-hero__svg-container:hover .page-svg__layer--node1,
    .page-hero__svg-container:hover .page-svg__layer--bubble1,
    .page-hero__svg-container:hover .page-svg__layer--card2,
    .page-hero__svg-container:hover .page-svg__layer--badge2,
    .page-hero__svg-container:hover .page-svg__layer--node2,
    .page-hero__svg-container:hover .page-svg__layer--bubble2,
    .page-hero__svg-container:hover .page-svg__layer--card3,
    .page-hero__svg-container:hover .page-svg__layer--badge3,
    .page-hero__svg-container:hover .page-svg__layer--node3,
    .page-hero__svg-container:hover .page-svg__layer--at,
    .page-hero__svg-container:hover .page-svg__layer--card4,
    .page-hero__svg-container:hover .page-svg__layer--node4,
    .page-hero__svg-container:hover .page-svg__layer--icons {
        transform: translate(0, -6px);
    }
}

/* ============================================
   PREVIEW CARDS SECTION (Home Page)
   ============================================ */
.preview-cards {
    background: var(--color-white);
}

.preview-cards__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}

.preview-card {
    display: flex;
    flex-direction: column;
    background: white;
    border-radius: 16px;
    padding: 2rem;
    text-decoration: none;
    color: inherit;
    border: 1px solid var(--color-border);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.preview-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(30, 58, 95, 0.12);
    border-color: var(--color-orange);
}

.preview-card__badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: var(--color-orange);
    color: white;
    padding: 0.25rem 0.75rem;
    border-radius: 2px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.preview-card__icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-dark) 100%);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    margin-bottom: 1.25rem;
    transition: transform 0.3s ease;
}

.preview-card:hover .preview-card__icon {
    transform: scale(1.1);
}

.preview-card--featured .preview-card__icon {
    background: linear-gradient(135deg, var(--color-orange) 0%, #ea580c 100%);
}

.preview-card__title {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-text-dark);
    margin-bottom: 0.75rem;
}

.preview-card__text {
    font-size: 0.9375rem;
    color: var(--color-text-light);
    line-height: 1.6;
    flex-grow: 1;
    margin-bottom: 1rem;
}

.preview-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-orange);
    font-weight: 600;
    font-size: 0.9375rem;
    transition: gap 0.3s ease;
}

.preview-card:hover .preview-card__link {
    gap: 0.75rem;
}

/* ============================================
   SECTION CTA
   ============================================ */
.section-cta {
    text-align: center;
    margin-top: 4rem;
    padding: 3rem;
    background: linear-gradient(135deg, var(--color-navy-dark) 0%, var(--color-navy) 100%);
    border-radius: 20px;
    position: relative;
    overflow: hidden;
}

.section-cta::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 40%;
    height: 100%;
    background: radial-gradient(circle at 100% 0%, rgba(249, 115, 22, 0.15) 0%, transparent 50%);
    pointer-events: none;
}

.section-cta__title {
    font-family: var(--font-heading);
    font-size: 1.75rem;
    font-weight: 700;
    color: white;
    margin-bottom: 0.75rem;
    position: relative;
    z-index: 1;
}

.section-cta__text {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 1.5rem;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    z-index: 1;
}

.section-cta__buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

/* ============================================
   AUTOMATION PAGE - INTRO BENEFITS
   ============================================ */
.automation-intro__benefits {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}

.automation-benefit {
    text-align: center;
    padding: 2rem;
    background: white;
    border-radius: 16px;
    border: 1px solid var(--color-border);
    transition: all 0.3s ease;
}

.automation-benefit:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px rgba(30, 58, 95, 0.1);
}

.automation-benefit__icon {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, rgba(249, 115, 22, 0.1) 0%, rgba(249, 115, 22, 0.05) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.5rem;
    color: var(--color-orange);
}

.automation-benefit__title {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-text-dark);
    margin-bottom: 0.75rem;
}

.automation-benefit__text {
    font-size: 0.9375rem;
    color: var(--color-text-light);
    line-height: 1.6;
}

/* ============================================
   AUTOMATION PAGE - INTEGRATIONS GRID
   ============================================ */
.automation-integrations {
    background: var(--color-bg-light);
}

.integrations__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
    max-width: 900px;
    margin: 0 auto;
}

.integration-badge {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.25rem;
    background: white;
    border: 1px solid var(--color-border);
    border-radius: 50px;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--color-text-dark);
    transition: all 0.3s ease;
}

.integration-badge:hover {
    border-color: var(--color-orange);
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(249, 115, 22, 0.15);
}

.integration-badge iconify-icon {
    color: var(--color-navy);
}

.integration-badge--more {
    background: var(--color-navy);
    color: white;
    border-color: var(--color-navy);
}

.integration-badge--more iconify-icon {
    color: white;
}

/* ============================================
   AUTOMATION PAGE - PROCESS STEPS
   ============================================ */
.process__steps {
    max-width: 700px;
    margin: 0 auto;
}

.process-step {
    display: flex;
    gap: 1.5rem;
    padding: 1.5rem 0;
    position: relative;
}

.process-step:not(:last-child)::after {
    content: '';
    position: absolute;
    left: 24px;
    top: 60px;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--color-orange) 0%, var(--color-border) 100%);
}

.process-step__number {
    width: 50px;
    height: 50px;
    min-width: 50px;
    background: linear-gradient(135deg, var(--color-orange) 0%, #ea580c 100%);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    position: relative;
    z-index: 1;
}

.process-step__content {
    padding-top: 0.5rem;
}

.process-step__title {
    font-family: var(--font-heading);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-text-dark);
    margin-bottom: 0.5rem;
}

.process-step__text {
    font-size: 0.9375rem;
    color: var(--color-text-light);
    line-height: 1.6;
}

/* ============================================
   AUTOMATION PAGE - CTA CARD
   ============================================ */
.automation-cta__card {
    background: linear-gradient(135deg, var(--color-navy-dark) 0%, var(--color-navy) 100%);
    border-radius: 24px;
    padding: 4rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.automation-cta__card::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 60%;
    height: 200%;
    background: radial-gradient(circle, rgba(249, 115, 22, 0.15) 0%, transparent 50%);
    pointer-events: none;
}

.automation-cta__content {
    position: relative;
    z-index: 1;
}

.automation-cta__title {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4vw, 2.25rem);
    font-weight: 700;
    color: white;
    margin-bottom: 1rem;
}

.automation-cta__text {
    font-size: 1.125rem;
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 2rem;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

.automation-cta__text strong {
    color: var(--color-orange);
    font-size: 1.5rem;
}

.automation-cta__buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* ============================================
   HOME STATS SECTION
   ============================================ */
.home-stats {
    padding: 2rem 0 3rem;
    background: white;
}

.home-stats .features__stats {
    padding-top: 0;
}

@media (max-width: 900px) {
    /* Hero split collapses to single column */
    .hero__split {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .hero__split-left {
        padding-top: 110px;
    }

    .hero__split-left__inner {
        padding: 3rem 1.5rem 3rem;
    }

    .hero__split-right {
        padding: 3rem 1.5rem;
        min-height: 340px;
    }

    /* Asymmetric grid collapses */
    .preview-cards__asymmetric-grid {
        grid-template-columns: 1fr;
    }

    .preview-cards__right-grid {
        grid-template-columns: 1fr 1fr;
    }

    .preview-card--large {
        min-height: 280px;
    }

    .preview-card--advisor-cta {
        flex-direction: column !important;
        align-items: flex-start;
    }
}

@media (max-width: 768px) {
    .preview-cards__grid {
        grid-template-columns: 1fr;
    }

    .preview-cards__right-grid {
        grid-template-columns: 1fr;
    }

    .section-cta {
        padding: 2rem;
    }

    .section-cta__title {
        font-size: 1.5rem;
    }

    .automation-cta__card {
        padding: 2.5rem 1.5rem;
    }

    .process-step {
        gap: 1rem;
    }

    .process-step__number {
        width: 40px;
        height: 40px;
        min-width: 40px;
        font-size: 1rem;
    }

    .process-step:not(:last-child)::after {
        left: 19px;
        top: 50px;
    }
}

/* ============================================
   AUTOMATION ADVISOR SECTION
   AI-Powered Business Process Assessment
   ============================================ */

.advisor {
    background: linear-gradient(180deg, var(--color-bg-light) 0%, var(--color-white) 100%);
    position: relative;
    overflow: hidden;
}

.advisor::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-border), transparent);
}

.advisor__badge {
    display: inline-block;
    background: linear-gradient(135deg, var(--color-orange) 0%, var(--color-orange-light) 100%);
    color: var(--color-white);
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.5rem 1rem;
    border-radius: var(--radius-full);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 1rem;
}

.advisor__wrapper {
    max-width: 1100px;
    margin: 0 auto;
}

/* Advisor Form Container */
.advisor__form-container {
    background: var(--color-white);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--color-border);
    overflow: hidden;
}

.advisor__form {
    padding: 2.5rem;
}

.advisor__form-header {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--color-border);
}

.advisor__form-icon {
    width: 56px;
    height: 56px;
    min-width: 56px;
    background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 100%);
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.advisor__form-title {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.25rem;
}

.advisor__form-subtitle {
    font-size: 0.95rem;
    color: var(--color-text-light);
    line-height: 1.5;
}

.advisor__form .form__group {
    margin-bottom: 1.5rem;
}

.advisor__form .form__label {
    display: block;
    font-weight: 600;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
    font-size: 0.95rem;
}

.advisor__form .form__textarea {
    width: 100%;
    padding: 1rem 1.25rem;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-text-dark);
    background: var(--color-white);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    resize: vertical;
    min-height: 150px;
}

.advisor__form .form__textarea:focus {
    outline: none;
    border-color: var(--color-orange);
    box-shadow: 0 0 0 4px rgba(249, 115, 22, 0.1);
}

.advisor__form .form__textarea::placeholder {
    color: var(--color-text-lighter);
}

.advisor__form .form__hint {
    font-size: 0.85rem;
    color: var(--color-text-light);
    margin-top: 0.5rem;
}

.advisor__form-footer {
    margin-top: 2rem;
}

.advisor__form .btn--full {
    width: 100%;
    padding: 1rem 2rem;
    font-size: 1.1rem;
}

.advisor__form .btn__text,
.advisor__form .btn__loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.advisor__disclaimer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 1rem;
    font-size: 0.85rem;
    color: var(--color-text-light);
}

.advisor__disclaimer iconify-icon {
    color: var(--color-orange);
}

/* Spinning animation for loading */
@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.spin {
    animation: spin 1s linear infinite;
}

/* Advisor Loading Overlay */
.advisor__loading-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100vw;
    height: 100vh;
    height: 100dvh; /* Dynamic viewport height for mobile */
    background: rgba(30, 58, 95, 0.92);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 99999;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
    /* Mobile scroll prevention */
    touch-action: none;
    -webkit-overflow-scrolling: auto;
    overscroll-behavior: contain;
    /* Ensure it breaks out of any parent constraints */
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.advisor__loading-overlay.active {
    display: flex !important;
    opacity: 1;
}

/* Body class when loading overlay is active - prevents background scroll on mobile */
body.advisor-loading-active {
    overflow: hidden;
    position: fixed;
    width: 100%;
    height: 100%;
    /* Preserve scroll position */
    top: var(--scroll-position, 0);
}

.advisor__loading-content {
    text-align: center;
    padding: 3rem;
    max-width: 400px;
}

.advisor__loading-svg {
    width: 120px;
    height: 120px;
    margin: 0 auto 2rem;
}

.advisor__loading-svg svg {
    width: 100%;
    height: 100%;
}

/* Rotating rings animation */
.advisor__loading-ring--outer {
    transform-origin: center;
    animation: rotateClockwise 2s linear infinite;
}

.advisor__loading-ring--inner {
    transform-origin: center;
    animation: rotateCounterClockwise 1.5s linear infinite;
}

@keyframes rotateClockwise {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes rotateCounterClockwise {
    from { transform: rotate(0deg); }
    to { transform: rotate(-360deg); }
}

/* Gear rotation */
.advisor__loading-gear {
    transform-origin: center;
    animation: rotateGear 3s linear infinite;
}

@keyframes rotateGear {
    from { transform: translate(60px, 60px) rotate(0deg); }
    to { transform: translate(60px, 60px) rotate(360deg); }
}

/* Pulsing dots animation */
.advisor__loading-dot {
    opacity: 0.3;
}

.advisor__loading-dot--1 {
    animation: pulseDot 1.4s ease-in-out infinite;
}

.advisor__loading-dot--2 {
    animation: pulseDot 1.4s ease-in-out 0.2s infinite;
}

.advisor__loading-dot--3 {
    animation: pulseDot 1.4s ease-in-out 0.4s infinite;
}

@keyframes pulseDot {
    0%, 100% { opacity: 0.3; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.3); }
}

.advisor__loading-title {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-white);
    margin-bottom: 0.75rem;
}

.advisor__loading-text {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.6;
    margin-bottom: 2rem;
}

.advisor__loading-progress {
    width: 100%;
    height: 4px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-full);
    overflow: hidden;
}

.advisor__loading-progress-bar {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--color-orange), var(--color-orange-light));
    border-radius: var(--radius-full);
    animation: progressIndeterminate 2s ease-in-out infinite;
}

@keyframes progressIndeterminate {
    0% {
        width: 0%;
        margin-left: 0%;
    }
    50% {
        width: 60%;
        margin-left: 20%;
    }
    100% {
        width: 0%;
        margin-left: 100%;
    }
}

/* Mobile adjustments for loading overlay */
@media (max-width: 768px) {
    .advisor__loading-overlay {
        /* Force full screen coverage on mobile */
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        height: 100dvh !important;
        min-height: -webkit-fill-available;
        z-index: 99999 !important;
        flex-direction: column;
    }

    .advisor__loading-content {
        padding: 1.5rem;
        max-width: 90%;
        margin: auto;
    }

    .advisor__loading-svg {
        width: 90px;
        height: 90px;
        margin-bottom: 1.25rem;
    }

    .advisor__loading-title {
        font-size: 1.15rem;
        margin-bottom: 0.5rem;
    }

    .advisor__loading-text {
        font-size: 0.85rem;
        line-height: 1.5;
        margin-bottom: 1.5rem;
    }

    .advisor__loading-progress {
        max-width: 250px;
        margin: 0 auto;
    }
}

/* Advisor Results Container */
.advisor__results {
    background: var(--color-white);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--color-border);
    overflow: hidden;
}

.advisor__results-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 2rem 2.5rem;
    background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 100%);
    color: var(--color-white);
}

.advisor__results-icon {
    width: 56px;
    height: 56px;
    min-width: 56px;
    background: rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
}

.advisor__results-title {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.advisor__results-subtitle {
    font-size: 0.9rem;
    opacity: 0.85;
}

.advisor__new-assessment {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: var(--color-white);
    padding: 0.6rem 1rem;
    border-radius: var(--radius-lg);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.advisor__new-assessment:hover {
    background: rgba(255, 255, 255, 0.25);
}

.advisor__results-content {
    padding: 2.5rem;
}

/* Assessment Section Styles */
.assessment-section {
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--color-border);
}

.assessment-section:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.assessment-section__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.assessment-section__number {
    width: 26px;
    height: 26px;
    min-width: 26px;
    background: var(--color-orange);
    color: var(--color-white);
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 700;
}

.assessment-section__title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-navy);
}

.assessment-section__content {
    padding-left: 2.75rem;
}

.assessment-section__content p {
    color: var(--color-text-dark);
    line-height: 1.7;
    margin-bottom: 0.75rem;
}

.assessment-section__content p:last-child {
    margin-bottom: 0;
}

.assessment-section__content ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.assessment-section__content li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.6rem;
    color: var(--color-text-dark);
    line-height: 1.6;
}

.assessment-section__content li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.6em;
    width: 6px;
    height: 6px;
    background: var(--color-orange);
    border-radius: var(--radius-full);
}

.assessment-section__content li:last-child {
    margin-bottom: 0;
}

/* Process Level Badge */
.assessment-level {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.25rem;
    background: var(--color-orange-lighter);
    border: 1px solid rgba(249, 115, 22, 0.2);
    border-radius: var(--radius-lg);
    font-weight: 600;
    color: var(--color-orange-dark);
}

.assessment-level iconify-icon {
    color: var(--color-orange);
}

/* Next Step Box */
.assessment-next-step {
    background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 100%);
    color: var(--color-white);
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    margin-top: 1rem;
}

.assessment-next-step p {
    color: var(--color-white) !important;
    margin: 0;
    line-height: 1.7;
}

/* Results CTA */
.advisor__results-cta {
    padding: 2rem 2.5rem;
    background: var(--color-bg-light);
    border-top: 1px solid var(--color-border);
    text-align: center;
}

.advisor__results-cta-text {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-navy);
    margin-bottom: 1.25rem;
}

.advisor__results-buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* Download Section */
.advisor__download-section {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.advisor__download-text {
    font-size: 0.95rem;
    color: var(--color-text-light);
    margin-bottom: 0.75rem;
}

.btn--outline {
    background: transparent;
    border: 2px solid var(--color-navy);
    color: var(--color-navy);
    padding: 0.75rem 1.5rem;
    border-radius: var(--radius-lg);
    font-weight: 600;
    font-size: 0.95rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: all 0.3s ease;
    text-decoration: none;
}

.btn--outline:hover {
    background: var(--color-navy);
    color: var(--color-white);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(30, 58, 95, 0.3);
}

/* Contrast-safe outline treatment for dark surfaces */
.btn--outline.btn--light {
    border-color: rgba(255, 255, 255, 0.7);
    color: var(--color-white);
    background: transparent;
}

.btn--outline.btn--light:hover,
.btn--outline.btn--light:focus-visible {
    background: var(--color-white);
    border-color: var(--color-white);
    color: var(--color-navy);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
}

.btn--download iconify-icon {
    font-size: 1.2rem;
}

/* Download Modal */
.download-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.download-modal.active {
    opacity: 1;
    visibility: visible;
}

.download-modal__backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
}

.download-modal__container {
    position: relative;
    background: var(--color-white);
    border-radius: var(--radius-xl, 16px);
    padding: 2.5rem;
    max-width: 480px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    transform: translateY(20px) scale(0.95);
    transition: transform 0.3s ease;
}

.download-modal.active .download-modal__container {
    transform: translateY(0) scale(1);
}

.download-modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-text-light);
    padding: 0.5rem;
    border-radius: 50%;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.download-modal__close:hover {
    background: var(--color-bg-light);
    color: var(--color-navy);
}

.download-modal__header {
    text-align: center;
    margin-bottom: 1.5rem;
}

.download-modal__icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, #dc2626, #ef4444);
    color: white;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
}

.download-modal__title {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.download-modal__subtitle {
    font-size: 0.95rem;
    color: var(--color-text-light);
    line-height: 1.5;
}

.download-modal__form .form__group {
    margin-bottom: 1rem;
}

.download-modal__form .form__label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-navy);
    margin-bottom: 0.375rem;
}

.download-modal__form .form__input {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-size: 0.95rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    color: var(--color-text);
}

.download-modal__form .form__input:focus {
    outline: none;
    border-color: var(--color-orange);
    box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.1);
}

.download-modal__footer {
    margin-top: 1.5rem;
}

.download-modal__disclaimer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    font-size: 0.8rem;
    color: var(--color-text-light);
    margin-top: 0.75rem;
}

/* Error State */
.advisor__error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #dc2626;
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    text-align: center;
}

.advisor__error-icon {
    margin-bottom: 0.75rem;
}

.advisor__error-title {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.advisor__error-text {
    font-size: 0.95rem;
    opacity: 0.9;
}

/* ---- Advisor Step Indicator ---- */
.advisor-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 2.5rem;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}
.advisor-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}
.advisor-step__circle {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 2px solid var(--color-border);
    background: var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    transition: all 0.3s ease;
}
.advisor-step__label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: color 0.3s ease;
}
.advisor-step__connector {
    flex: 1;
    height: 2px;
    background: var(--color-border);
    margin: 0 0.5rem;
    margin-bottom: 1.25rem;
    min-width: 40px;
}
.advisor-step--active .advisor-step__circle {
    border-color: var(--color-orange);
    background: var(--color-orange);
    color: var(--color-white);
}
.advisor-step--active .advisor-step__label {
    color: var(--color-orange);
}
.advisor-step--complete .advisor-step__circle {
    border-color: var(--color-navy);
    background: var(--color-navy);
    color: var(--color-white);
}
.advisor-step--complete .advisor-step__label {
    color: var(--color-navy);
}

/* ---- Advisor Prompt Chips ---- */
.advisor-prompts {
    margin-bottom: 1.5rem;
}
.advisor-prompts__label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.75rem;
}
.advisor-prompts__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.advisor-prompt-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.875rem;
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: 3px;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--color-navy);
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}
.advisor-prompt-chip:hover {
    background: var(--color-navy);
    border-color: var(--color-navy);
    color: var(--color-white);
}
.advisor-prompt-chip.is-selected {
    background: var(--color-orange);
    border-color: var(--color-orange);
    color: var(--color-white);
}

/* ---- Advisor Form Meta / Char Counter ---- */
.advisor-form__meta {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 0.5rem;
    gap: 1rem;
}
.advisor-char-counter {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ---- Advisor Results Summary Bar ---- */
.advisor__results-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    background: var(--color-navy);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    padding: 1rem 2rem;
    margin-bottom: 0;
}
.advisor__results-summary-item {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: 0 2rem 0 0;
    border-right: 1px solid rgba(255,255,255,0.15);
    margin-right: 2rem;
}
.advisor__results-summary-item:last-child {
    border-right: none;
    margin-right: 0;
    padding-right: 0;
}
.advisor__results-summary-label {
    font-size: 0.7rem;
    font-weight: 600;
    color: rgba(255,255,255,0.55);
    text-transform: uppercase;
    letter-spacing: 0.07em;
}
.advisor__results-summary-value {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--color-white);
}

/* ---- Advisor How-It-Works Inline Row ---- */
.advisor-how-it-works {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 2rem;
    padding: 1.25rem 1.5rem;
    background: var(--color-bg-light);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}
.advisor-how-it-works__step {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
}
.advisor-how-it-works__num {
    width: 30px;
    height: 30px;
    min-width: 30px;
    border-radius: 50%;
    background: var(--color-orange);
    color: var(--color-white);
    font-size: 0.82rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}
.advisor-how-it-works__text {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}
.advisor-how-it-works__text strong {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-navy);
}
.advisor-how-it-works__text span {
    font-size: 0.78rem;
    color: var(--color-text-muted);
}
.advisor-how-it-works__arrow {
    color: var(--color-border);
    font-size: 1.1rem;
    margin: 0 0.75rem;
    flex-shrink: 0;
}

/* Responsive Styles for Advisor */
@media (max-width: 768px) {
    .advisor__wrapper {
        max-width: 100%;
        padding: 0;
    }

    .advisor__form-container {
        border-radius: var(--radius-lg);
        margin: 0 -0.5rem;
    }

    .advisor__form {
        padding: 1.25rem;
    }

    .advisor__form-header {
        flex-direction: column;
        text-align: center;
        gap: 0.75rem;
        margin-bottom: 1.5rem;
        padding-bottom: 1.25rem;
    }

    .advisor__form-icon {
        margin: 0 auto;
        width: 48px;
        height: 48px;
        min-width: 48px;
    }

    .advisor__form-icon iconify-icon {
        width: 24px;
        height: 24px;
    }

    .advisor__form-title {
        font-size: 1.25rem;
    }

    .advisor__form-subtitle {
        font-size: 0.9rem;
    }

    .advisor__form .form__textarea {
        min-height: 120px;
        font-size: 16px; /* Prevents zoom on iOS */
        padding: 0.875rem 1rem;
    }

    .advisor__form .form__label {
        font-size: 0.9rem;
    }

    .advisor__form .form__hint {
        font-size: 0.8rem;
    }

    .advisor__form-footer {
        margin-top: 1.5rem;
    }

    .advisor__form .btn--full {
        padding: 0.875rem 1.5rem;
        font-size: 1rem;
    }

    .advisor__disclaimer {
        font-size: 0.8rem;
        flex-wrap: wrap;
        justify-content: center;
    }

    /* Results Mobile Styles */
    .advisor__results {
        border-radius: var(--radius-lg);
        margin: 0 -0.5rem;
    }

    .advisor__results-header {
        flex-direction: column;
        text-align: center;
        padding: 1.25rem;
        gap: 0.75rem;
    }

    .advisor__results-icon {
        width: 48px;
        height: 48px;
        min-width: 48px;
        margin: 0 auto;
    }

    .advisor__results-icon iconify-icon {
        width: 24px;
        height: 24px;
    }

    .advisor__results-title {
        font-size: 1.15rem;
    }

    .advisor__results-subtitle {
        font-size: 0.85rem;
    }

    .advisor__new-assessment {
        margin-left: 0;
        margin-top: 0.5rem;
        padding: 0.625rem 1rem;
        font-size: 0.85rem;
    }

    .advisor__results-content {
        padding: 1.25rem;
    }

    .assessment-section {
        margin-bottom: 1.25rem;
    }

    .assessment-section__header {
        margin-bottom: 0.75rem;
    }

    .assessment-section__number {
        width: 28px;
        height: 28px;
        min-width: 28px;
        font-size: 0.85rem;
    }

    .assessment-section__title {
        font-size: 1rem;
    }

    .assessment-section__content {
        padding-left: 0;
        font-size: 0.9rem;
    }

    .assessment-section__content ul {
        padding-left: 1.25rem;
    }

    .assessment-section__content li {
        margin-bottom: 0.5rem;
    }

    .advisor__results-cta {
        padding: 1.25rem;
    }

    .advisor__results-cta-text {
        font-size: 0.95rem;
        margin-bottom: 1rem;
    }

    .advisor__results-buttons {
        flex-direction: column;
        gap: 0.75rem;
    }

    .advisor__results-buttons .btn {
        width: 100%;
        padding: 0.875rem 1.25rem;
        font-size: 0.95rem;
    }

    /* Download section mobile */
    .advisor__download-section {
        margin-top: 1.25rem;
        padding-top: 1.25rem;
    }

    .btn--outline {
        width: 100%;
        justify-content: center;
        padding: 0.875rem 1.25rem;
    }

    .download-modal__container {
        padding: 1.5rem;
        width: 95%;
    }

    .download-modal__title {
        font-size: 1.15rem;
    }

    /* Error state mobile */
    .advisor__error {
        padding: 1.25rem;
    }

    .advisor__error-icon iconify-icon {
        width: 40px;
        height: 40px;
    }

    .advisor__error-title {
        font-size: 1rem;
    }

    .advisor__error-text {
        font-size: 0.875rem;
    }

    /* Assessment level badge mobile */
    .assessment-level {
        padding: 0.625rem 1rem;
        font-size: 0.9rem;
    }

    /* Next step box mobile */
    .assessment-next-step {
        padding: 1.25rem;
        margin-top: 0.75rem;
    }

    .assessment-next-step p {
        font-size: 0.9rem;
        line-height: 1.6;
    }

    /* Step indicator mobile */
    .advisor-steps {
        max-width: 100%;
    }
    .advisor-step__connector {
        min-width: 20px;
    }
    .advisor-step__label {
        font-size: 0.65rem;
    }

    /* Prompt chips mobile */
    .advisor-prompt-chip {
        font-size: 0.75rem;
        padding: 0.4rem 0.65rem;
    }

    /* Results summary bar mobile */
    .advisor__results-summary {
        flex-direction: column;
        gap: 0.75rem;
        padding: 1rem 1.25rem;
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    }
    .advisor__results-summary-item {
        border-right: none;
        margin-right: 0;
        padding-right: 0;
        border-bottom: 1px solid rgba(255,255,255,0.1);
        padding-bottom: 0.75rem;
    }
    .advisor__results-summary-item:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

    /* How it works inline row mobile */
    .advisor-how-it-works {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
        padding: 1rem;
    }
    .advisor-how-it-works__arrow {
        transform: rotate(90deg);
        margin: 0;
        align-self: center;
    }
}

/* ============================================
   TECHNICAL WORKFLOW STYLES
   For the comprehensive automation assessment
   ============================================ */

/* Workflow Trigger */
.workflow-trigger {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem;
    background: linear-gradient(135deg, var(--color-orange-lighter) 0%, rgba(249, 115, 22, 0.05) 100%);
    border: 1px solid rgba(249, 115, 22, 0.2);
    border-radius: var(--radius-lg);
    margin-bottom: 1.5rem;
}

.workflow-trigger__icon {
    width: 48px;
    height: 48px;
    min-width: 48px;
    background: var(--color-orange);
    color: var(--color-white);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.workflow-trigger__title {
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.35rem;
}

.workflow-trigger__description {
    color: var(--color-text-dark);
    font-size: 0.9rem;
    line-height: 1.6;
    margin: 0;
}

/* Workflow Steps */
.workflow-steps {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.workflow-step {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    position: relative;
    transition: all var(--transition-fast);
}

.workflow-step:hover {
    border-color: var(--color-orange);
    box-shadow: var(--shadow-md);
}

.workflow-step__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.workflow-step__number {
    width: 28px;
    height: 28px;
    min-width: 28px;
    background: var(--color-navy);
    color: var(--color-white);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 700;
}

.workflow-step__info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex: 1;
    gap: 1rem;
}

.workflow-step__name {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-navy);
    margin: 0;
}

.workflow-step__duration {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.8rem;
    color: var(--color-orange);
    font-weight: 500;
    white-space: nowrap;
}

.workflow-step__description {
    color: var(--color-text-dark);
    font-size: 0.9rem;
    line-height: 1.6;
    margin: 0 0 0.75rem 0;
}

.workflow-step__systems {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.workflow-step__system {
    display: inline-block;
    background: var(--color-bg-lighter);
    color: var(--color-text-light);
    font-size: 0.75rem;
    font-weight: 500;
    padding: 0.3rem 0.65rem;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-border);
}

/* Workflow Processing Time */
.workflow-time {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.25rem;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: var(--color-white);
    border-radius: var(--radius-lg);
    margin-bottom: 1.5rem;
    font-size: 0.95rem;
}

.workflow-time iconify-icon {
    opacity: 0.9;
}

/* Workflow Integrations */
.workflow-integrations {
    margin-bottom: 1.5rem;
}

.workflow-integrations__title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-navy);
    margin-bottom: 0.75rem;
}

.workflow-integrations__title iconify-icon {
    color: var(--color-orange);
}

.workflow-integrations__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.workflow-integration {
    display: inline-flex;
    align-items: center;
    background: var(--color-navy);
    color: var(--color-white);
    font-size: 0.8rem;
    font-weight: 500;
    padding: 0.45rem 0.85rem;
    border-radius: var(--radius-full);
}

/* Workflow Conditional Logic */
.workflow-logic {
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
}

.workflow-logic__title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-navy);
    margin-bottom: 0.75rem;
}

.workflow-logic__title iconify-icon {
    color: var(--color-orange);
}

.workflow-logic__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.workflow-logic__list li {
    position: relative;
    padding: 0.6rem 0 0.6rem 1.75rem;
    color: var(--color-text-dark);
    font-size: 0.9rem;
    line-height: 1.5;
    font-family: 'Consolas', 'Monaco', monospace;
    border-bottom: 1px dashed var(--color-border);
}

.workflow-logic__list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.workflow-logic__list li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--color-orange);
    font-weight: 700;
}

/* Implementation Grid */
.implementation-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.implementation-item {
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
}

.implementation-item--highlight {
    background: linear-gradient(135deg, var(--color-orange-lighter) 0%, rgba(249, 115, 22, 0.05) 100%);
    border-color: rgba(249, 115, 22, 0.3);
}

.implementation-item__title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-light);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 0.5rem;
}

.implementation-item__title iconify-icon {
    color: var(--color-orange);
}

.implementation-item__value {
    color: var(--color-navy);
    font-size: 0.95rem;
    line-height: 1.6;
    margin: 0;
}

.implementation-item__value--large {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-orange-dark);
}

.implementation-item__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.implementation-item__list li {
    position: relative;
    padding-left: 1.25rem;
    margin-bottom: 0.4rem;
    color: var(--color-text-dark);
    font-size: 0.9rem;
    line-height: 1.5;
}

.implementation-item__list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #10b981;
    font-weight: 700;
}

.implementation-item__list li:last-child {
    margin-bottom: 0;
}

/* Impact List Enhancement */
.impact-list li::before {
    background: #10b981 !important;
}

/* Workflow Section Styling */
.assessment-section--workflow {
    background: var(--color-bg-light);
    margin-left: 0;
    margin-right: 0;
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}

.assessment-section--workflow .assessment-section__content {
    padding-left: 0;
}

/* Responsive Styles for Workflow */
@media (max-width: 768px) {
    .workflow-trigger {
        flex-direction: column;
        text-align: center;
        padding: 1rem;
    }

    .workflow-trigger__icon {
        margin: 0 auto;
        width: 40px;
        height: 40px;
        min-width: 40px;
    }

    .workflow-trigger__title {
        font-size: 0.9rem;
    }

    .workflow-trigger__description {
        font-size: 0.85rem;
    }

    .workflow-steps {
        gap: 0.75rem;
    }

    .workflow-step {
        padding: 1rem;
    }

    .workflow-step__header {
        flex-wrap: wrap;
        gap: 0.5rem;
    }

    .workflow-step__number {
        width: 28px;
        height: 28px;
        min-width: 28px;
        font-size: 0.8rem;
    }

    .workflow-step__info {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
        flex: 1;
    }

    .workflow-step__name {
        font-size: 0.9rem;
    }

    .workflow-step__duration {
        margin-top: 0.125rem;
        font-size: 0.75rem;
    }

    .workflow-step__description {
        font-size: 0.85rem;
    }

    .workflow-step__systems {
        gap: 0.375rem;
    }

    .workflow-step__system {
        font-size: 0.7rem;
        padding: 0.25rem 0.5rem;
    }

    .workflow-time {
        padding: 0.75rem 1rem;
        font-size: 0.85rem;
    }

    .workflow-integrations__title,
    .workflow-logic__title {
        font-size: 0.9rem;
    }

    .workflow-integrations__list {
        gap: 0.5rem;
    }

    .workflow-integration {
        font-size: 0.75rem;
        padding: 0.375rem 0.625rem;
    }

    .workflow-logic__list li {
        font-size: 0.8rem;
        padding-left: 1.5rem;
    }

    .implementation-grid {
        grid-template-columns: 1fr;
    }

    .implementation-item {
        padding: 1rem;
    }

    .implementation-item__title {
        font-size: 0.85rem;
    }

    .implementation-item__value {
        font-size: 0.9rem;
    }

    .implementation-item__list li {
        font-size: 0.85rem;
    }

    /* Workflow section card styling on mobile */
    .assessment-section--workflow {
        margin-left: 0;
        margin-right: 0;
        padding: 1rem;
        border-radius: var(--radius-lg);
        background: var(--color-bg-light);
        border: 1px solid var(--color-border);
    }

    .assessment-section--workflow .workflow-trigger {
        margin-bottom: 1rem;
    }

    .assessment-section--workflow .workflow-steps {
        gap: 0.75rem;
        margin-bottom: 1rem;
    }

    .assessment-section--workflow .workflow-time,
    .assessment-section--workflow .workflow-integrations,
    .assessment-section--workflow .workflow-logic {
        margin-bottom: 1rem;
    }
}

/* ============================================
   ADVISOR BANNER - Promotional CTA Section
   ============================================ */

.advisor-banner {
    background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 100%);
    padding: 1.5rem 0;
    position: relative;
    overflow: hidden;
}

.advisor-banner::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    opacity: 0.5;
}

.advisor-banner__content {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    position: relative;
    z-index: 1;
}

.advisor-banner__icon {
    width: 56px;
    height: 56px;
    min-width: 56px;
    background: linear-gradient(135deg, var(--color-orange) 0%, var(--color-orange-light) 100%);
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
    box-shadow: 0 4px 15px rgba(249, 115, 22, 0.3);
}

.advisor-banner__text {
    flex: 1;
}

.advisor-banner__title {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-white);
    margin-bottom: 0.25rem;
}

.advisor-banner__description {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
}

.advisor-banner .btn--sm {
    padding: 0.65rem 1.25rem;
    font-size: 0.9rem;
    white-space: nowrap;
}

/* Responsive */
@media (max-width: 768px) {
    .advisor-banner__content {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
    }

    .advisor-banner__icon {
        margin: 0 auto;
    }

    .advisor-banner .btn--sm {
        width: 100%;
    }
}

/* ============================================
   STATS STRIP
   ============================================ */
.stats-strip {
    background: transparent;
    padding: clamp(2.75rem, 5vw, 4.25rem) 0;
    margin-top: clamp(1.25rem, 3vw, 2.5rem);
    width: 100%;
}

.stats-strip .container {
    background: linear-gradient(135deg, var(--color-navy-dark) 0%, var(--color-navy) 60%, var(--color-navy-light) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-lg);
    padding: clamp(1.4rem, 2.2vw, 2rem);
    box-shadow: 0 14px 32px rgba(15, 39, 68, 0.2);
    position: relative;
    overflow: hidden;
}

.stats-strip .container::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(249, 115, 22, 0.1) 0%, transparent 65%);
    pointer-events: none;
}

.stats-strip .stats-strip__eyebrow {
    position: relative;
    z-index: 1;
    margin: 0 0 1.25rem;
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.stats-strip__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    position: relative;
    z-index: 1;
}

.stats-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0.6rem;
    min-height: 8.5rem;
    padding: 1rem;
    border-right: 1px solid rgba(255, 255, 255, 0.14);
    transition: background var(--transition-normal);
}

.stats-item:hover {
    background: rgba(255, 255, 255, 0.05);
}

.stats-item:last-child {
    border-right: none;
}

.stats-item__icon {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(249, 115, 22, 0.2);
    color: #ffd2a8;
    font-size: 1rem;
    line-height: 1;
}

.stats-item__number {
    display: flex;
    align-items: baseline;
    justify-content: flex-start;
    gap: 0.1rem;
    margin-bottom: 0.25rem;
}

.stats-item__count {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 3vw, 2.65rem);
    font-weight: 800;
    color: #ff9e42;
    line-height: 1;
}

.stats-item__suffix {
    font-family: var(--font-heading);
    font-size: clamp(1rem, 2vw, 1.35rem);
    font-weight: 700;
    color: #ffb366;
}

.stats-strip .stats-item__label {
    font-size: 0.94rem;
    color: rgba(255, 255, 255, 0.86);
    font-weight: 500;
    letter-spacing: 0.01em;
    margin: 0;
    line-height: 1.45;
}

@media (max-width: 992px) {
    .stats-strip__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .stats-item {
        border-right: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    }

    .stats-item:nth-last-child(-n + 2) {
        border-bottom: none;
    }
}

@media (max-width: 640px) {
    .stats-strip {
        padding: 2.5rem 0;
    }

    .stats-strip .stats-strip__eyebrow {
        margin-bottom: 1rem;
    }

    .stats-strip__grid {
        grid-template-columns: 1fr;
        gap: 0.85rem;
    }

    .stats-item {
        min-height: auto;
        padding: 0.9rem;
        border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    }

    .stats-item:last-child {
        border-bottom: none;
    }
}

/* ============================================
   BEFORE vs AFTER TOGGLE
   ============================================ */
.before-after {
    background: var(--color-white);
}


.ba-panels {
    max-width: 1200px;
    margin: 0 auto 2rem;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
    align-items: start;
}

.ba-panel {
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
    animation: baFadeIn 0.35s ease;
}

.ba-panel--hidden {
    display: none;
}

@keyframes baFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

.ba-panel__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    background: var(--color-navy);
    color: var(--color-white);
    font-size: 0.9rem;
    font-weight: 600;
}

.ba-panel__header--after {
    background: linear-gradient(135deg, #f97316 0%, #fb923c 100%);
}

.ba-steps {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    background: var(--color-white);
}

.ba-step {
    display: grid;
    grid-template-columns: 44px 1fr auto;
    align-items: center;
    gap: 1rem;
    padding: 0.875rem 1rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    background: var(--color-bg-light);
}

.ba-step--manual {
    border-color: rgba(239, 68, 68, 0.15);
    background: rgba(254, 242, 242, 0.5);
}

.ba-step--auto {
    border-color: rgba(249, 115, 22, 0.2);
    background: rgba(255, 247, 237, 0.8);
}

.ba-step__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    color: var(--color-navy);
    flex-shrink: 0;
}

.ba-step--auto .ba-step__icon {
    color: var(--color-orange);
    border-color: rgba(249, 115, 22, 0.35);
}

.ba-step__body {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.ba-step__name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-dark);
}

.ba-step__time {
    font-size: 0.8rem;
    color: var(--color-text-light);
}

.ba-step__tag {
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0.25rem 0.625rem;
    border-radius: var(--radius-full);
    white-space: nowrap;
    letter-spacing: 0.03em;
}

.ba-step__tag--pain {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.ba-step__tag--win {
    background: rgba(249, 115, 22, 0.12);
    color: #c2410c;
}

.ba-connector {
    width: 2px;
    height: 20px;
    margin: 0 auto;
    margin-left: 30px;
    border-radius: 1px;
}

.ba-connector--manual {
    background: linear-gradient(to bottom, rgba(239, 68, 68, 0.3), rgba(239, 68, 68, 0.1));
}

.ba-connector--auto {
    background: linear-gradient(to bottom, rgba(249, 115, 22, 0.45), rgba(249, 115, 22, 0.12));
}

.ba-panel__footer {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    align-items: center;
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--color-border);
    font-size: 0.82rem;
    font-weight: 600;
    background: var(--color-bg-light);
}

.ba-panel__footer span {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--color-text-light);
}

.ba-panel__footer--before span { color: var(--color-text-light); }
.ba-panel__footer--after span { color: #c2410c; }

.ba-cta {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.ba-cta p {
    font-size: 1rem;
    color: var(--color-text-light);
    margin: 0;
}

@media (max-width: 960px) {
    .ba-panels {
        grid-template-columns: 1fr;
        max-width: 720px;
    }
}

@media (max-width: 640px) {
    .ba-step {
        grid-template-columns: 36px 1fr;
        grid-template-rows: auto auto;
    }

    .ba-step__tag {
        grid-column: 2;
        width: fit-content;
    }

    .ba-panel__footer {
        gap: 0.75rem;
    }
}

/* ============================================
   USE CASES / INDUSTRIES SECTION
   ============================================ */
.use-cases__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.use-case-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 1.75rem;
    transition: all var(--transition-normal);
    position: relative;
    overflow: hidden;
}

.use-case-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-orange) 0%, var(--color-orange-light) 100%);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--transition-normal);
}

.use-case-card:hover {
    box-shadow: var(--shadow-xl);
    border-color: transparent;
    transform: translateY(-3px);
}

.use-case-card:hover::before {
    transform: scaleX(1);
}

.use-case-card__icon {
    width: 52px;
    height: 52px;
    background: linear-gradient(135deg, rgba(249, 115, 22, 0.1) 0%, rgba(249, 115, 22, 0.05) 100%);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-orange);
    margin-bottom: 1rem;
}

.use-case-card__industry {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 1rem;
}

.use-case-card__list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.use-case-card__list li {
    font-size: 0.85rem;
    color: var(--color-text-light);
    padding-left: 1.25rem;
    position: relative;
    line-height: 1.5;
}

.use-case-card__list li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--color-orange);
    font-weight: 700;
}

.use-case-card__saving {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8rem;
    color: #059669;
    background: rgba(16, 185, 129, 0.08);
    border: 1px solid rgba(16, 185, 129, 0.2);
    padding: 0.375rem 0.75rem;
    border-radius: var(--radius-full);
}

.use-case-card__saving strong {
    font-weight: 700;
}

.use-cases__footer {
    text-align: center;
    font-size: 0.95rem;
    color: var(--color-text-light);
}

.use-cases__footer a {
    color: var(--color-orange);
    font-weight: 600;
    text-decoration: none;
}

.use-cases__footer a:hover { text-decoration: underline; }

@media (max-width: 900px) {
    .use-cases__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
    .use-cases__grid { grid-template-columns: 1fr; }
}

/* ============================================
   ROI CALCULATOR
   ============================================ */
.roi-calculator {
    background: var(--color-white);
}

.roi-calc__wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
    align-items: start;
    max-width: 960px;
    margin: 0 auto;
}

.roi-calc__group {
    margin-bottom: 1.75rem;
}

.roi-calc__label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text-dark);
    margin-bottom: 0.75rem;
}

.roi-calc__select {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-size: 0.9rem;
    font-family: var(--font-body);
    color: var(--color-text-dark);
    background: var(--color-white);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%2364748b' d='m7 10l5 5l5-5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    padding-right: 2.5rem;
    transition: border-color var(--transition-fast);
}

.roi-calc__select:focus {
    outline: none;
    border-color: var(--color-orange);
    box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.1);
}

.roi-calc__slider-wrap {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.roi-calc__slider {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 6px;
    border-radius: 3px;
    background: var(--color-border);
    outline: none;
    cursor: pointer;
}

.roi-calc__slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--color-orange);
    border: 3px solid white;
    box-shadow: 0 2px 8px rgba(249, 115, 22, 0.4);
    cursor: pointer;
    transition: box-shadow var(--transition-fast);
}

.roi-calc__slider::-webkit-slider-thumb:hover {
    box-shadow: 0 2px 16px rgba(249, 115, 22, 0.5);
}

.roi-calc__slider-labels {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.78rem;
    color: var(--color-text-lighter);
}

.roi-calc__slider-val {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-navy);
    background: rgba(30, 58, 95, 0.06);
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius-full);
}

.roi-results {
    background: var(--color-navy-dark);
    border-radius: var(--radius-xl);
    padding: 2rem;
    color: var(--color-white);
    position: sticky;
    top: 100px;
}

.roi-results__header {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 1.5rem;
    font-size: 0.8rem;
}

.roi-result-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.875rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.roi-result-item:last-of-type { border-bottom: none; }

.roi-result-item--highlight {
    background: rgba(249, 115, 22, 0.12);
    border-radius: var(--radius-lg);
    padding: 0.875rem 1rem;
    margin: 0.5rem -1rem;
    border-bottom: none;
}

.roi-result-item__label {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
}

.roi-result-item--highlight .roi-result-item__label {
    color: rgba(255, 255, 255, 0.9);
    font-weight: 600;
}

.roi-result-item__value {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--color-white);
}

.roi-result-item--highlight .roi-result-item__value {
    color: var(--color-orange-light);
    font-size: 1.4rem;
}

.roi-payback {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: #34d399;
    margin: 1.5rem 0 1.25rem;
    padding: 0.75rem;
    background: rgba(16, 185, 129, 0.1);
    border-radius: var(--radius-lg);
}

.roi-results__cta {
    width: 100%;
    justify-content: center;
    margin-top: 0.5rem;
}

/* ROI Calculator Results Side — matching HTML class names */
.roi-calc__results-side {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.roi-calc__result-card {
    background: var(--color-navy-dark);
    border-radius: var(--radius-xl);
    padding: 1.75rem;
    color: var(--color-white);
    position: sticky;
    top: 100px;
}

.roi-calc__result-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.875rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.roi-calc__result-item:last-of-type { border-bottom: none; }

.roi-calc__result-item--highlight {
    background: rgba(249, 115, 22, 0.15);
    border-radius: var(--radius-lg);
    padding: 1rem 1.25rem;
    margin: 0.5rem -1.25rem;
    border-bottom: none;
}

.roi-calc__result-label {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.4;
}

.roi-calc__result-item--highlight .roi-calc__result-label {
    color: rgba(255, 255, 255, 0.9);
    font-weight: 600;
}

.roi-calc__result-value {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--color-white);
    text-align: right;
    white-space: nowrap;
    margin-left: 1rem;
}

.roi-calc__result-item--highlight .roi-calc__result-value {
    color: var(--color-orange-light);
    font-size: 1.5rem;
}

/* Savings values stand out with large green text + glow */
.roi-calc__result-value--green {
    color: #4ade80;
    font-size: 1.4rem;
    font-weight: 800;
    font-family: var(--font-heading);
    text-shadow: 0 0 20px rgba(74, 222, 128, 0.35);
}

.roi-calc__cta {
    margin-top: 1rem;
    width: 100%;
    text-align: center;
    display: block;
}

@media (max-width: 768px) {
    .roi-calc__wrapper {
        grid-template-columns: 1fr;
    }

    .roi-results {
        position: static;
    }

    .roi-calc__result-card {
        position: static;
    }
}

/* ============================================
   AUTOMATION READINESS QUIZ
   ============================================ */
.quiz-section {
    background: var(--color-bg-light);
}

.quiz-wrapper {
    max-width: 680px;
    margin: 0 auto;
}

.quiz-progress {
    height: 6px;
    background: var(--color-border);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 0.75rem;
}

.quiz-progress__bar {
    height: 100%;
    background: linear-gradient(90deg, var(--color-orange) 0%, var(--color-orange-light) 100%);
    border-radius: 3px;
    transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.quiz-counter {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text-light);
    text-align: right;
    margin-bottom: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.quiz-questions {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2rem;
    margin-bottom: 1.25rem;
    min-height: 280px;
    box-shadow: var(--shadow-md);
}

.quiz-question {
    display: none;
}

.quiz-question.active {
    display: block;
    animation: baFadeIn 0.3s ease;
}

.quiz-question__text {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 1.5rem;
    line-height: 1.5;
}

.quiz-options {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.quiz-option {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 0.875rem 1.25rem;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
    font-size: 0.9rem;
    color: var(--color-text-dark);
}

.quiz-option:hover {
    border-color: var(--color-orange);
    background: rgba(249, 115, 22, 0.04);
}

.quiz-option input[type="radio"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-orange);
    flex-shrink: 0;
    cursor: pointer;
}

.quiz-option:has(input:checked),
.quiz-option--checked {
    border-color: var(--color-orange);
    background: rgba(249, 115, 22, 0.06);
    color: var(--color-navy);
    font-weight: 600;
}

.quiz-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.quiz-result {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2.5rem 2rem;
    box-shadow: var(--shadow-lg);
    display: flex;
    gap: 2rem;
    align-items: center;
    animation: baFadeIn 0.4s ease;
}

.quiz-result__score-ring {
    width: 120px;
    height: 120px;
    flex-shrink: 0;
    position: relative;
}

.quiz-score-ring {
    width: 100%;
    height: 100%;
}

.quiz-score-ring__arc {
    transition: stroke-dashoffset 1s cubic-bezier(0.4, 0, 0.2, 1);
}

.quiz-result__score-text {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.quiz-result__score-num {
    font-family: var(--font-heading);
    font-size: 2rem;
    font-weight: 800;
    color: var(--color-navy);
    line-height: 1;
}

.quiz-result__score-max {
    font-size: 0.8rem;
    color: var(--color-text-light);
}

.quiz-result__title {
    font-family: var(--font-heading);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.quiz-result__desc {
    font-size: 0.9rem;
    color: var(--color-text-light);
    margin-bottom: 1.25rem;
    line-height: 1.6;
}

.quiz-result__actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    align-items: center;
}

@media (max-width: 560px) {
    .quiz-result {
        flex-direction: column;
        text-align: center;
    }

    .quiz-result__actions {
        flex-direction: column;
        width: 100%;
    }

    .quiz-result__actions .btn {
        width: 100%;
        justify-content: center;
    }
}

/* ============================================
   INSIGHTS SECTION
   ============================================ */
.insights {
    background: var(--color-white);
}

.insights-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.insights-loading {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem;
    color: var(--color-text-light);
}

.insights-loading__spinner {
    width: 36px;
    height: 36px;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-orange);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 0 auto 1rem;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

.insight-card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: all var(--transition-normal);
    display: flex;
    flex-direction: column;
    background: var(--color-white);
    text-decoration: none;
    color: inherit;
}

.insight-card:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-3px);
    border-color: transparent;
}

.insight-card--featured {
    grid-column: span 2;
    flex-direction: row;
}

.insight-card__image {
    background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-light) 100%);
    min-height: 160px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.insight-card--featured .insight-card__image {
    width: 45%;
    min-height: 100%;
}

.insight-card__image-icon {
    color: rgba(255, 255, 255, 0.2);
}

.insight-card__image-cat {
    position: absolute;
    top: 0.875rem;
    left: 0.875rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    background: var(--color-orange);
    color: white;
    padding: 0.25rem 0.625rem;
    border-radius: var(--radius-full);
}

.insight-card__body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.insight-card__meta {
    display: flex;
    gap: 0.875rem;
    font-size: 0.78rem;
    color: var(--color-text-lighter);
    margin-bottom: 0.75rem;
    align-items: center;
}

.insight-card__meta-dot {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--color-border);
}

.insight-card__title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.625rem;
    line-height: 1.4;
}

.insight-card--featured .insight-card__title {
    font-size: 1.2rem;
}

.insight-card__excerpt {
    font-size: 0.85rem;
    color: var(--color-text-light);
    line-height: 1.6;
    flex: 1;
    margin-bottom: 1rem;
}

.insight-card__read-more {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--color-orange);
    text-decoration: none;
    margin-top: auto;
}

.insights__footer {
    text-align: center;
}

.insights__view-all {
    display: inline-flex;
}

@media (max-width: 900px) {
    .insights-grid { grid-template-columns: repeat(2, 1fr); }
    .insight-card--featured { grid-column: span 2; flex-direction: column; }
    .insight-card--featured .insight-card__image { width: 100%; min-height: 160px; }
}

@media (max-width: 560px) {
    .insights-grid { grid-template-columns: 1fr; }
    .insight-card--featured { grid-column: span 1; }
}

/* ============================================
   DISCOVERY CALL CTA
   ============================================ */
.discovery-cta {
    background: linear-gradient(135deg, var(--color-navy-dark) 0%, var(--color-navy) 60%, var(--color-navy-light) 100%);
    position: relative;
    overflow: hidden;
}

.discovery-cta::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(249, 115, 22, 0.08) 0%, transparent 65%);
    pointer-events: none;
}

.discovery-cta__inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4rem;
    align-items: center;
    position: relative;
    z-index: 1;
}

.discovery-cta__eyebrow {
    display: inline-block;
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.65);
    background: none;
    border: none;
    border-top: 2px solid rgba(249, 115, 22, 0.7);
    border-radius: 0;
    padding: 0.45rem 0 0;
    box-shadow: none;
    margin-bottom: 0.875rem;
}

.discovery-cta__title {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3.5vw, 2.5rem);
    font-weight: 800;
    color: var(--color-white);
    margin-bottom: 1rem;
    line-height: 1.2;
}

.discovery-cta__desc {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.7;
    margin-bottom: 1.5rem;
    max-width: 540px;
}

.discovery-cta__list {
    list-style: none;
    padding: 0;
    margin: 0 0 2rem 0;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.discovery-cta__list li {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.85);
}

.discovery-cta__list iconify-icon {
    color: #34d399;
    flex-shrink: 0;
}

.discovery-cta__actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.btn--lg {
    padding: 1rem 2rem;
    font-size: 1rem;
}

/* Discovery Card */
.discovery-cta__card {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-xl);
    overflow: hidden;
    min-width: 300px;
    backdrop-filter: blur(8px);
}

.discovery-cta__card-header {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1.25rem 1.5rem;
    background: rgba(255, 255, 255, 0.06);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.discovery-cta__avatar {
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, var(--color-orange) 0%, var(--color-orange-light) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    flex-shrink: 0;
}

.discovery-cta__name {
    font-weight: 700;
    color: var(--color-white);
    font-size: 0.9rem;
    margin: 0 0 0.1rem;
}

.discovery-cta__role {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.5);
    margin: 0;
}

.discovery-cta__status {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    color: #34d399;
    font-weight: 600;
}

.discovery-cta__status-dot {
    width: 8px;
    height: 8px;
    background: #34d399;
    border-radius: 50%;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.6; transform: scale(0.8); }
}

.discovery-cta__agenda {
    padding: 1.25rem 1.5rem;
}

.discovery-cta__agenda-title {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.875rem;
}

.discovery-cta__agenda-item {
    display: flex;
    gap: 0.875rem;
    align-items: flex-start;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
}

.discovery-cta__agenda-item:last-child { border-bottom: none; }

.discovery-cta__agenda-time {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-orange-light);
    min-width: 40px;
    padding-top: 0.05rem;
}

.discovery-cta__card-footer {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.5rem;
    background: rgba(255, 255, 255, 0.04);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.5);
}

@media (max-width: 900px) {
    .discovery-cta__inner {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .discovery-cta__card {
        min-width: unset;
    }
}

/* ============================================
   SLA / SECURITY SECTION
   ============================================ */
.sla-section {
    background: var(--color-bg-light);
}

.sla-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 3rem;
}

.sla-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 1.75rem;
    transition: all var(--transition-normal);
}

.sla-card:hover {
    box-shadow: var(--shadow-lg);
    border-color: transparent;
    transform: translateY(-2px);
}

.sla-card__icon {
    width: 52px;
    height: 52px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.25rem;
}

.sla-card__icon--green {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.sla-card__icon--blue {
    background: rgba(30, 58, 95, 0.1);
    color: var(--color-navy);
}

.sla-card__icon--orange {
    background: rgba(249, 115, 22, 0.1);
    color: var(--color-orange);
}

.sla-card__title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.625rem;
}

.sla-card__desc {
    font-size: 0.875rem;
    color: var(--color-text-light);
    line-height: 1.65;
    margin: 0;
}

.sla-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
}

.sla-badge {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 1.25rem;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-navy);
    box-shadow: var(--shadow-sm);
}

.sla-badge iconify-icon {
    color: var(--color-orange);
}

@media (max-width: 900px) {
    .sla-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
    .sla-grid { grid-template-columns: 1fr; }
}

/* ============================================
   WHATSAPP QUICK-REPLY PANEL
   ============================================ */
.wa-widget {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: var(--z-fixed);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.75rem;
}

.wa-trigger {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: #25D366;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    box-shadow: 0 4px 20px rgba(37, 211, 102, 0.45);
    transition: all var(--transition-normal);
    position: relative;
    flex-shrink: 0;
}

.wa-trigger:hover {
    transform: scale(1.08);
    box-shadow: 0 6px 28px rgba(37, 211, 102, 0.55);
}

.wa-trigger__badge {
    position: absolute;
    top: -4px;
    right: -4px;
    width: 20px;
    height: 20px;
    background: var(--color-orange);
    color: white;
    font-size: 0.7rem;
    font-weight: 700;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid white;
    animation: bounce 1.5s ease infinite;
}

@keyframes bounce {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.2); }
}

.wa-panel {
    background: var(--color-white);
    border-radius: var(--radius-xl);
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.15);
    width: 320px;
    overflow: hidden;
    display: none;
    border: 1px solid var(--color-border);
    animation: waPanelIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.wa-panel.wa-panel--open {
    display: block;
}

@keyframes waPanelIn {
    from { opacity: 0; transform: translateY(16px) scale(0.96); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

.wa-panel__header {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1rem 1.25rem;
    background: #128C7E;
    color: white;
}

.wa-panel__avatar {
    width: 38px;
    height: 38px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.wa-panel__info { flex: 1; }

.wa-panel__name {
    font-weight: 700;
    font-size: 0.9rem;
    margin: 0 0 0.1rem;
}

.wa-panel__status {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
}

.wa-panel__dot {
    width: 7px;
    height: 7px;
    background: #25D366;
    border-radius: 50%;
    animation: pulse 2s infinite;
}

.wa-panel__close {
    background: rgba(255, 255, 255, 0.15);
    border: none;
    color: white;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background var(--transition-fast);
}

.wa-panel__close:hover { background: rgba(255, 255, 255, 0.25); }

.wa-panel__body {
    padding: 1.25rem;
    background: #ECE5DD;
}

.wa-panel__bubble {
    background: white;
    border-radius: 0 var(--radius-lg) var(--radius-lg) var(--radius-lg);
    padding: 0.875rem 1rem;
    font-size: 0.875rem;
    color: var(--color-text-dark);
    line-height: 1.55;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
    max-width: 85%;
}

.wa-panel__bubble p {
    margin: 0 0 0.5rem;
}

.wa-panel__bubble p:last-of-type {
    margin-bottom: 0;
}

.wa-panel__time {
    display: block;
    font-size: 0.7rem;
    color: var(--color-text-lighter);
    text-align: right;
    margin-top: 0.375rem;
}

.wa-panel__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.625rem;
    padding: 1rem 1.25rem;
    background: #25D366;
    color: white;
    font-weight: 700;
    font-size: 0.9rem;
    text-decoration: none;
    transition: background var(--transition-fast);
}

.wa-panel__cta:hover { background: #20ba5a; }

/* New pricing section wrappers */
.pricing-compare,
.ai-included {
    background: var(--color-bg-light);
}

.ai-scope,
.ai-process {
    background: var(--color-white);
}

.section-cta__inner {
    position: relative;
    z-index: 1;
}

/* Section Tag utility */
.section__tag {
    display: inline-block;
    background: none;
    border: none;
    border-top: 2px solid var(--color-orange);
    border-radius: 0;
    padding: 0.45rem 0 0;
    color: var(--color-text-light);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 0.875rem;
    box-shadow: none;
}

/* ============================================
   PRICING WEB DEVELOPMENT — NEW SECTIONS
   ============================================ */

/* ROI Calc Grid */
.roi-calc__grid {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: var(--spacing-xl);
    align-items: start;
}

.roi-calc__inputs-side {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.roi-calc__input-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.roi-calc__package-select {
    margin-top: 0.5rem;
}

.roi-calc__pkg-btns {
    display: flex;
    gap: 0.75rem;
    margin-top: 0.75rem;
}

.roi-calc__pkg-btn {
    flex: 1;
    padding: 0.75rem 0.5rem;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-white);
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-dark);
    cursor: pointer;
    text-align: center;
    transition: border-color var(--transition-fast), background var(--transition-fast), color var(--transition-fast);
    line-height: 1.4;
}

.roi-calc__pkg-btn small {
    display: block;
    font-weight: 400;
    color: var(--color-text-lighter);
    font-size: 0.78rem;
}

.roi-calc__pkg-btn:hover {
    border-color: var(--color-orange);
    color: var(--color-orange);
}

.roi-calc__pkg-btn--active {
    border-color: var(--color-orange);
    background: rgba(249, 115, 22, 0.07);
    color: var(--color-orange);
}

.roi-calc__pkg-btn--active small {
    color: var(--color-orange);
    opacity: 0.8;
}

@media (max-width: 900px) {
    .roi-calc__grid {
        grid-template-columns: 1fr;
    }
}

/* Feature Comparison Table */
.compare-table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-md);
    margin-bottom: var(--spacing-xl);
}

.compare-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--color-white);
    font-size: 0.9rem;
}

.compare-table thead {
    background: var(--color-navy);
    color: var(--color-white);
}

.compare-table thead th {
    padding: 1.25rem 1rem;
    text-align: center;
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 0.95rem;
    vertical-align: middle;
}

.compare-table thead th.compare-table__feature-col {
    text-align: left;
    padding-left: 1.5rem;
}

.compare-table thead th.compare-table__featured {
    background: var(--color-orange);
}

.compare-table thead th span {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    opacity: 0.85;
    margin-top: 0.25rem;
}

.compare-table tbody tr {
    border-bottom: 1px solid var(--color-border);
    transition: background var(--transition-fast);
}

.compare-table tbody tr:last-child { border-bottom: none; }

.compare-table tbody tr:hover { background: rgba(30, 58, 95, 0.03); }

.compare-table tbody td {
    padding: 0.875rem 1rem;
    text-align: center;
    color: var(--color-text);
    vertical-align: middle;
}

.compare-table tbody td:first-child {
    text-align: left;
    padding-left: 1.5rem;
    font-weight: 500;
    color: var(--color-text-dark);
}

.compare-table tbody td.compare-table__featured {
    background: rgba(249, 115, 22, 0.05);
}

.compare-check {
    color: #059669;
    font-size: 1.2rem;
}

.compare-cross {
    color: #94a3b8;
    font-size: 1.2rem;
}

/* Trust Signal Cards */
.trust-signals {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
}

.trust-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2rem 1.5rem;
    text-align: center;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.trust-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-3px);
}

.trust-card__icon {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-lg);
    background: rgba(249, 115, 22, 0.08);
    color: var(--color-orange);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.25rem;
}

.trust-card__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.trust-card__text {
    font-size: 0.9rem;
    color: var(--color-text);
    line-height: 1.6;
}

@media (max-width: 768px) {
    .trust-signals {
        grid-template-columns: 1fr;
    }
}

/* FAQ Section */
.faq-section {
    background: var(--color-bg-light);
}

.faq-list {
    max-width: 760px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.faq-item {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: box-shadow var(--transition-fast);
}

.faq-item:hover,
.faq-item.faq-item--open {
    box-shadow: var(--shadow-sm);
}

.faq-item__question {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    background: none;
    border: none;
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text-dark);
    cursor: pointer;
    text-align: left;
    transition: color var(--transition-fast);
}

.faq-item__question:hover { color: var(--color-orange); }

.faq-item--open .faq-item__question { color: var(--color-orange); }

.faq-item__icon {
    flex-shrink: 0;
    transition: transform var(--transition-fast);
    color: var(--color-text-lighter);
}

.faq-item--open .faq-item__icon {
    transform: rotate(180deg);
    color: var(--color-orange);
}

.faq-item__answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease;
}

.faq-item--open .faq-item__answer {
    max-height: 400px;
}

.faq-item__answer p {
    padding: 0 1.5rem 1.25rem;
    font-size: 0.9rem;
    color: var(--color-text);
    line-height: 1.7;
    margin: 0;
}

/* ============================================
   AI PRICING PAGE — SCOPE TIERS & TIMELINE
   ============================================ */

/* Scope Tier Cards */
.scope-tier-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-lg);
    align-items: start;
}

.scope-tier-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-2xl);
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    position: relative;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.scope-tier-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
}

.scope-tier-card--featured {
    background: var(--color-navy);
    border-color: var(--color-navy);
    box-shadow: var(--shadow-lg);
}

.scope-tier-card--featured:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 60px rgba(30, 58, 95, 0.35);
}

.scope-tier-card__badge {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-orange);
    color: white;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.3rem 1rem;
    border-radius: var(--radius-xl);
    white-space: nowrap;
}

.scope-tier-card__header {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.scope-tier-card__icon {
    width: 52px;
    height: 52px;
    border-radius: var(--radius-lg);
    background: rgba(249, 115, 22, 0.1);
    color: var(--color-orange);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.25rem;
}

.scope-tier-card--featured .scope-tier-card__icon {
    background: rgba(249, 115, 22, 0.2);
}

.scope-tier-card__title {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--color-navy);
    margin: 0;
}

.scope-tier-card--featured .scope-tier-card__title {
    color: var(--color-white);
}

.scope-tier-card__subtitle {
    font-size: 0.875rem;
    color: var(--color-text);
    margin: 0;
    line-height: 1.5;
}

.scope-tier-card--featured .scope-tier-card__subtitle {
    color: rgba(255, 255, 255, 0.7);
}

.scope-tier-card__price {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 1rem;
    background: rgba(30, 58, 95, 0.04);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(249, 115, 22, 0.28);
}

.scope-tier-card--featured .scope-tier-card__price {
    background: rgba(255, 255, 255, 0.08);
}

.scope-tier-card__price-range {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--color-navy);
}

.scope-tier-card--featured .scope-tier-card__price-range {
    color: var(--color-orange-light);
}

.scope-tier-card__timeline {
    font-size: 0.8rem;
    color: var(--color-text-lighter);
    font-weight: 500;
}

.scope-tier-card--featured .scope-tier-card__timeline {
    color: rgba(255, 255, 255, 0.55);
}

.scope-tier-card__features {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    flex: 1;
}

.scope-tier-card__features li {
    font-size: 0.875rem;
    color: var(--color-text);
    padding-left: 1.4rem;
    position: relative;
    line-height: 1.5;
}

.scope-tier-card__features li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.45em;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-orange);
    flex-shrink: 0;
}

.scope-tier-card--featured .scope-tier-card__features li {
    color: rgba(255, 255, 255, 0.8);
}

.scope-tier-card--featured .scope-tier-card__features li::before {
    background: var(--color-orange-light);
}

@media (max-width: 960px) {
    .scope-tier-cards {
        grid-template-columns: 1fr;
        max-width: 480px;
        margin: 0 auto;
    }
}

/* AI Always Included Checklist */
.ai-checklist {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
}

.ai-checklist__item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 1.25rem 1.5rem;
    transition: box-shadow var(--transition-fast);
}

.ai-checklist__item:hover { box-shadow: var(--shadow-sm); }

.ai-checklist__icon {
    font-size: 1.5rem;
    color: #059669;
    flex-shrink: 0;
    margin-top: 0.1rem;
}

.ai-checklist__item strong {
    display: block;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.3rem;
}

.ai-checklist__item p {
    font-size: 0.875rem;
    color: var(--color-text);
    line-height: 1.6;
    margin: 0;
}

@media (max-width: 640px) {
    .ai-checklist {
        grid-template-columns: 1fr;
    }
}

/* AI Process Timeline */
.ai-timeline {
    display: flex;
    align-items: flex-start;
    gap: 0;
}

.ai-timeline__step {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
}

.ai-timeline__step-num {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-lg);
    background: var(--color-navy);
    color: var(--color-orange);
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.25rem;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}

.ai-timeline__connector {
    flex: 0 0 60px;
    height: 2px;
    background: linear-gradient(90deg, var(--color-navy) 0%, rgba(30, 58, 95, 0.2) 100%);
    margin-top: 27px;
    align-self: flex-start;
}

.ai-timeline__step-content h4 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.ai-timeline__step-content p {
    font-size: 0.85rem;
    color: var(--color-text);
    line-height: 1.6;
    margin: 0;
    max-width: 180px;
}

@media (max-width: 768px) {
    .ai-timeline {
        flex-direction: column;
        gap: 0;
        align-items: stretch;
    }
    .ai-timeline__step {
        flex-direction: row;
        align-items: flex-start;
        text-align: left;
        gap: 1.25rem;
    }
    .ai-timeline__step-num {
        margin-bottom: 0;
        flex-shrink: 0;
    }
    .ai-timeline__connector {
        width: 2px;
        height: 40px;
        flex: 0;
        margin: 0 0 0 27px;
        background: linear-gradient(180deg, var(--color-navy) 0%, rgba(30, 58, 95, 0.2) 100%);
    }
    .ai-timeline__step-content p {
        max-width: none;
    }
}

/* ============================================
   SOCIAL PROOF STRIP
   ============================================ */
.proof-strip__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
}

.proof-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 1.25rem;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.proof-card__title {
    margin-bottom: 0.5rem;
    font-size: 1.05rem;
}

.proof-card__result {
    color: var(--color-text-dark);
    margin-bottom: 0.5rem;
}

.proof-card__meta {
    color: var(--color-text-light);
    font-size: 0.9rem;
}

/* ============================================
   CONTACT FUNNEL
   ============================================ */
.contact-funnel__progress {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.contact-funnel__step {
    border: 1px solid var(--color-border);
    border-radius: 999px;
    padding: 0.35rem 0.8rem;
    font-size: 0.85rem;
    color: var(--color-text-light);
}

.contact-funnel__step--active {
    background: rgba(16, 185, 129, 0.12);
    color: var(--color-green);
    border-color: rgba(16, 185, 129, 0.45);
}

.contact-funnel__actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.contact__next-steps {
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1rem;
    background: rgba(16, 185, 129, 0.04);
}

.contact__next-steps ul {
    margin: 0.5rem 0 0;
    padding-left: 1rem;
}

/* Cookie controls */
.cookie-banner__btn--manage {
    background: transparent;
    color: var(--color-text-dark);
    border: 1px solid var(--color-border);
}

/* ============================================
   ACCESSIBILITY: SKIP LINK
   ============================================ */
.skip-link {
    position: absolute;
    top: -100%;
    left: 1rem;
    z-index: 9999;
    padding: 0.75rem 1.25rem;
    background: var(--color-orange);
    color: var(--color-white);
    font-weight: 700;
    font-size: 0.95rem;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    text-decoration: none;
    transition: top 0.2s ease;
}
.skip-link:focus {
    top: 0;
}

/* ============================================
   ACCESSIBILITY: FOCUS VISIBLE STATES
   ============================================ */
.btn:focus-visible,
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 3px solid var(--color-orange);
    outline-offset: 3px;
    border-radius: var(--radius-sm);
}

/* ============================================
   PROOF CARD: CHALLENGE TEXT + LINK
   ============================================ */
.proof-card__challenge {
    color: var(--color-text-light);
    font-size: 0.9rem;
    margin-bottom: 0.625rem;
    font-style: italic;
}

.proof-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-top: 0.75rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-orange-dark);
    text-decoration: none;
    transition: gap var(--transition-fast);
}
.proof-card__link:hover {
    gap: 0.5rem;
    color: var(--color-orange);
}

/* ============================================
   TRUST BAR
   ============================================ */
.trust-bar {
    background: var(--color-bg-light);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    padding: 0.875rem 0;
}

.trust-bar__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.5rem 1.5rem;
    text-align: center;
}

.trust-bar__label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text-light);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0;
}

.trust-bar__sectors {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.25rem;
    align-items: center;
    justify-content: center;
}

.trust-bar__sector {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--color-navy);
    white-space: nowrap;
}

.trust-bar__divider {
    color: var(--color-orange);
    font-weight: 700;
}

/* ============================================
   TESTIMONIALS SECTION
   ============================================ */
.testimonials {
    padding: var(--spacing-2xl) 0;
}

.testimonials__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: var(--spacing-xl);
}

.testimonial-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: 2rem;
    box-shadow: 0 8px 24px rgba(15, 39, 68, 0.06);
    position: relative;
}

.testimonial-card::before {
    content: '\201C';
    position: absolute;
    top: 1rem;
    left: 1.5rem;
    font-size: 4rem;
    line-height: 1;
    color: var(--color-orange);
    opacity: 0.2;
    font-family: Georgia, serif;
    pointer-events: none;
}

.testimonial-card__quote {
    color: var(--color-text-dark);
    font-size: 1rem;
    line-height: 1.7;
    margin-bottom: 1.25rem;
    padding-top: 0.5rem;
}

.testimonial-card__author {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.testimonial-card__avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--color-orange-lighter);
    border: 2px solid rgba(249, 115, 22, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-orange-dark);
    flex-shrink: 0;
}

.testimonial-card__name {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--color-navy);
    margin: 0;
}

.testimonial-card__role {
    font-size: 0.8rem;
    color: var(--color-text-light);
    margin: 0;
}

/* ============================================
   CASE STUDIES PAGE
   ============================================ */
.case-study-block {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 3rem;
    align-items: start;
    padding: var(--spacing-xl) 0;
    border-bottom: 1px solid var(--color-border);
}

.case-study-block:last-of-type {
    border-bottom: none;
}

.case-study-block__sidebar {
    position: sticky;
    top: 6rem;
}

.case-study-block__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}

.case-study-block__badge {
    display: inline-block;
    padding: 0.3rem 0.75rem;
    font-size: 0.78rem;
    font-weight: 700;
    border-radius: var(--radius-full);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.case-study-block__badge--industry {
    background: rgba(30, 58, 95, 0.08);
    color: var(--color-navy);
    border: 1px solid rgba(30, 58, 95, 0.18);
}

.case-study-block__badge--service {
    background: var(--color-orange-lighter);
    color: var(--color-orange-dark);
    border: 1px solid rgba(249, 115, 22, 0.24);
}

.case-study-block__title {
    font-size: clamp(1.35rem, 2.5vw, 1.75rem);
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.case-study-block__timeline {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    color: var(--color-text-light);
    margin-top: 0.75rem;
}

.case-study-block__metric-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1.5rem;
}

.case-study-metric {
    flex: 1;
    min-width: 100px;
    text-align: center;
    padding: 1rem;
    background: var(--color-bg-light);
    border-radius: 12px;
    border: 1px solid var(--color-border);
}

.case-study-metric__value {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--color-orange);
    font-family: var(--font-heading);
    display: block;
    line-height: 1.1;
}

.case-study-metric__label {
    font-size: 0.78rem;
    color: var(--color-text-light);
    margin-top: 0.25rem;
    display: block;
}

.case-study-block__body {}

.case-study-block__section-title {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-orange-dark);
    margin-bottom: 0.5rem;
    margin-top: 0;
}

.case-study-block__text {
    color: var(--color-text-dark);
    line-height: 1.7;
}

.case-study-block__list {
    padding-left: 1.25rem;
    margin-bottom: 1rem;
}

.case-study-block__list li {
    color: var(--color-text-dark);
    margin-bottom: 0.4rem;
    line-height: 1.6;
}

.case-study-block__cta {
    margin-top: 1.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 600;
    color: var(--color-orange-dark);
    font-size: 0.9rem;
    text-decoration: none;
    transition: gap var(--transition-fast);
}
.case-study-block__cta:hover { gap: 0.6rem; }

/* Responsive case study block */
@media (max-width: 768px) {
    .case-study-block {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
    .case-study-block__sidebar {
        position: static;
    }
}

/* ============================================
   INDUSTRIES PAGE
   ============================================ */
.industry-section {
    padding: var(--spacing-xl) 0;
    border-bottom: 1px solid var(--color-border);
}

.industry-section:last-of-type {
    border-bottom: none;
}

.industry-section__header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.industry-section__icon {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    background: var(--color-orange-lighter);
    border: 1px solid rgba(249, 115, 22, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-orange-dark);
    flex-shrink: 0;
}

.industry-section__name {
    font-size: clamp(1.2rem, 2.5vw, 1.5rem);
    color: var(--color-navy);
    margin: 0 0 0.2rem;
}

.industry-section__saving {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.82rem;
    font-weight: 700;
    color: #10b981;
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.25);
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius-full);
}

.industry-section__use-cases {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.industry-use-case {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: 10px;
}

.industry-use-case__icon {
    color: var(--color-orange);
    flex-shrink: 0;
    margin-top: 0.1rem;
}

.industry-use-case__title {
    font-weight: 700;
    font-size: 0.92rem;
    color: var(--color-navy);
    margin: 0 0 0.2rem;
}

.industry-use-case__desc {
    font-size: 0.85rem;
    color: var(--color-text-light);
    margin: 0;
    line-height: 1.5;
}

/* ============================================
   CONTACT PAGE ENHANCEMENTS
   ============================================ */
.contact-intro {
    text-align: center;
    max-width: 620px;
    margin: 0 auto var(--spacing-md);
}

.contact-intro__text {
    color: var(--color-text-light);
    font-size: 1.05rem;
    line-height: 1.6;
    margin: 0;
}

/* ============================================
   SERVICE PAGE PROOF STRIP
   ============================================ */
.service-proof-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
    align-items: stretch;
    margin-bottom: var(--spacing-md);
}

.service-proof-item {
    flex: 1;
    min-width: 200px;
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    padding: 1.125rem 1.25rem;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(15, 39, 68, 0.05);
}

.service-proof-item__icon {
    color: var(--color-orange);
    flex-shrink: 0;
    margin-top: 0.15rem;
}

.service-proof-item__value {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--color-navy);
    font-family: var(--font-heading);
    display: block;
    line-height: 1.1;
}

.service-proof-item__label {
    font-size: 0.83rem;
    color: var(--color-text-light);
    display: block;
    margin-top: 0.15rem;
}

/* ============================================
   WHY US: CLIENT JOURNEY SECTION
   ============================================ */
.client-journey {
    padding: var(--spacing-2xl) 0;
}

.client-journey__steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(200px, 100%), 1fr));
    gap: 1.5rem;
    margin-top: var(--spacing-xl);
}

.client-journey__step {
    text-align: center;
    padding: 1.75rem 1.25rem;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    box-shadow: 0 6px 20px rgba(15, 39, 68, 0.05);
    position: relative;
}

.client-journey__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--color-orange);
    color: var(--color-white);
    font-weight: 800;
    font-size: 1.05rem;
    font-family: var(--font-heading);
    margin-bottom: 1rem;
    box-shadow: 0 4px 12px rgba(249, 115, 22, 0.3);
}

.client-journey__step-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-navy);
    margin-bottom: 0.5rem;
}

.client-journey__step-desc {
    font-size: 0.88rem;
    color: var(--color-text-light);
    line-height: 1.6;
    margin: 0;
}


.compare-table-ctas {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.compare-table-ctas .btn {
    justify-content: center;
}

.contact-steps-card {
    background: #ffffff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.contact-steps-card__header {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1.25rem 1.5rem;
    background: rgba(249, 115, 22, 0.06);
    border-bottom: 1px solid var(--color-border);
}

.contact-steps-card__avatar {
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, var(--color-orange) 0%, var(--color-orange-light) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    flex-shrink: 0;
}

.contact-steps-card__name {
    font-weight: 700;
    color: var(--color-text-dark);
    font-size: 0.9rem;
    margin: 0 0 0.1rem;
}

.contact-steps-card__role {
    font-size: 0.78rem;
    color: var(--color-text-light);
    margin: 0;
}

.contact-steps-card__status {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    color: #10b981;
    font-weight: 600;
}

.contact-steps-card__status-dot {
    width: 8px;
    height: 8px;
    background: #10b981;
    border-radius: 50%;
}

.contact-steps-card__agenda {
    padding: 1.25rem 1.5rem;
}

.contact-steps-card__agenda-title {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--color-text-light);
    margin-bottom: 0.875rem;
}

.contact-steps-card__agenda-item {
    display: flex;
    gap: 0.875rem;
    align-items: flex-start;
    padding: 0.55rem 0;
    border-bottom: 1px solid var(--color-border);
    font-size: 0.9rem;
    color: var(--color-text-dark);
}

.contact-steps-card__agenda-item:last-child { border-bottom: none; }

.contact-steps-card__agenda-time {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-orange);
    min-width: 45px;
    padding-top: 0.05rem;
}

.contact-steps-card__footer {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.5rem;
    background: rgba(30, 58, 95, 0.04);
    border-top: 1px solid var(--color-border);
    font-size: 0.82rem;
    color: var(--color-text-light);
}

@media (max-width: 900px) {
    .compare-table-ctas {
        grid-template-columns: 1fr;
    }
}


/* Related services internal linking block */
.related-services {
    border-top: 1px solid var(--color-border);
}

.related-services__title {
    font-size: clamp(1.6rem, 3vw, 2.1rem);
    color: var(--color-navy);
    margin-bottom: var(--spacing-xs);
}

.related-services__intro {
    color: var(--color-text-light);
    max-width: 60ch;
    margin-bottom: var(--spacing-md);
}

.related-services__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--spacing-sm);
}

.related-services__item {
    display: block;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: 1.25rem;
    padding: 1rem 1.1rem;
    text-decoration: none;
    transition: transform var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal);
}

.related-services__item h3 {
    color: var(--color-navy);
    font-size: 1rem;
    margin: 0 0 var(--spacing-xs);
}

.related-services__item p {
    color: var(--color-text-light);
    font-size: 0.95rem;
    margin: 0;
}

.related-services__item:hover,
.related-services__item:focus-visible {
    border-color: var(--color-orange);
    box-shadow: 0 8px 24px rgba(15, 39, 68, 0.08);
    transform: translateY(-2px);
}
