/*
Theme Name:   RevoraOps Child
Theme URI:    https://revoraops.com
Description:  GeneratePress child theme for RevoraOps. Layout and fonts inspired by Cogneesol; colors from RevoraOps brand logo. Tagline: Automate. Optimize. Scale.
Author:       RevoraOps
Author URI:   https://revoraops.com
Template:     generatepress
Version:      3.0.0
Text Domain:  revoraops-child
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Geist:wght@400;500;600;700;800&display=swap');

/* =========================================================
   1. Design Tokens — Direction B "Editorial Enterprise"
   ========================================================= */
:root {
    /* Brand — dark navy commands, blue does the work, violet is the spice */
    --c-ink:            #0A1A3E;        /* dominant dark surface */
    --c-ink-2:          #0E2350;        /* layered dark sections */
    --c-primary:        #0A1A3E;        /* alias for legacy class compatibility */
    --c-primary-700:    #0E2350;
    --c-primary-900:    #050E26;
    --c-secondary:      #1E88FF;        /* primary CTA + links */
    --c-secondary-600:  #1872D9;        /* hover state */
    --c-accent:         #7C3AED;        /* stat numbers, eyebrow labels, link underlines */
    --c-accent-600:     #6D28D9;

    /* Gradients */
    --g-brand:          linear-gradient(135deg, #1E88FF 0%, #7C3AED 100%);
    --g-brand-soft:     linear-gradient(135deg, rgba(30,136,255,0.10) 0%, rgba(124,58,237,0.10) 100%);
    --g-dark:           linear-gradient(135deg, #0A1A3E 0%, #0E2350 100%);
    --g-dark-orb:       radial-gradient(circle at 80% 20%, rgba(124,58,237,0.22), transparent 55%),
                        radial-gradient(circle at 20% 80%, rgba(30,136,255,0.18), transparent 55%);
    --g-glow:           radial-gradient(circle at 10% 0%, rgba(30,136,255,0.20), transparent 40%),
                        radial-gradient(circle at 90% 100%, rgba(124,58,237,0.22), transparent 45%);

    /* Text */
    --c-text:           #1F2A44;
    --c-text-strong:    #0A1A3E;
    --c-text-light:     #5B6478;
    --c-text-faint:     #9CA3AF;
    --c-text-inverse:   #FFFFFF;
    --c-text-invert-muted: rgba(255,255,255,0.70);
    --c-heading:        #0A1A3E;

    /* Surfaces */
    --c-bg:             #FFFFFF;
    --c-bg-alt:         #F6F8FC;        /* paper-2: off-white */
    --c-bg-soft:        #EEF2F9;
    --c-bg-dark:        #0A1A3E;        /* ink */
    --c-border:         #E5E9F2;
    --c-border-strong:  #CDD3E1;
    --c-border-dark:    rgba(255,255,255,0.10);

    /* Status */
    --c-success: #10B981;
    --c-warning: #F59E0B;
    --c-danger:  #EF4444;

    /* Typography — Direction B: Geist display + Inter text */
    --ff-display: 'Geist', system-ui, -apple-system, sans-serif;
    --ff-heading: 'Geist', system-ui, -apple-system, sans-serif;
    --ff-body:    'Inter', system-ui, -apple-system, sans-serif;

    --fs-2xs: 11px;
    --fs-xs:  12px;
    --fs-sm:  14px;
    --fs-base:16px;
    --fs-md:  18px;
    --fs-lg:  20px;
    --fs-xl:  24px;
    --fs-2xl: 28px;
    --fs-3xl: 32px;
    --fs-4xl: 40px;
    --fs-5xl: 48px;
    --fs-6xl: 60px;

    /* Radii */
    --rad-sm:   6px;
    --rad-md:   10px;
    --rad-lg:   16px;
    --rad-xl:   20px;
    --rad-2xl:  28px;
    --rad-pill: 999px;

    /* Shadows */
    --sh-sm:  0 1px 2px rgba(11,31,74,0.06);
    --sh-md:  0 4px 14px rgba(11,31,74,0.10);
    --sh-lg:  0 14px 36px rgba(11,31,74,0.12);
    --sh-xl:  0 24px 60px rgba(11,31,74,0.18);
    --sh-glow:0 8px 24px rgba(30,136,255,0.35);
    --sh-glow-violet:0 8px 24px rgba(124,58,237,0.35);

    /* Spacing */
    --s-1:  0.25rem;
    --s-2:  0.5rem;
    --s-3:  0.75rem;
    --s-4:  1rem;
    --s-5:  1.25rem;
    --s-6:  1.5rem;
    --s-8:  2rem;
    --s-10: 2.5rem;
    --s-12: 3rem;
    --s-16: 4rem;
    --s-20: 5rem;
    --s-24: 6rem;
    --s-32: 8rem;

    /* Layout */
    --container: 1240px;
    --content:   780px;
    --section-y: var(--s-24);

    /* Motion */
    --ease:     cubic-bezier(0.4, 0, 0.2, 1);
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --dur:      0.25s;
    --dur-lg:   0.5s;
}

/* =========================================================
   1b. A11y — skip link + focus styles
   ========================================================= */
.r-skip-link {
    position: absolute;
    top: 0;
    left: 0;
    background: var(--c-secondary);
    color: #fff;
    font-family: var(--ff-body);
    font-weight: 600;
    font-size: 14px;
    padding: 12px 18px;
    border-radius: 0 0 var(--rad-md) 0;
    text-decoration: none;
    transform: translateY(-200%);
    transition: transform var(--dur) var(--ease);
    z-index: 9999;
}
.r-skip-link:focus,
.r-skip-link:focus-visible {
    transform: translateY(0);
    color: #fff;
    outline: 2px solid #fff;
    outline-offset: -4px;
}

/* Honor reduced motion site-wide */
@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;
    }
}

/* Visible focus outlines for keyboard nav (without breaking mouse styles) */
:focus-visible {
    outline: 2px solid var(--c-secondary);
    outline-offset: 3px;
    border-radius: 4px;
}
.r-btn:focus-visible {
    outline-offset: 4px;
    box-shadow: var(--sh-glow), 0 0 0 4px rgba(30,136,255,0.2);
}

/* =========================================================
   2. Reset + base
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: var(--ff-body);
    font-size: var(--fs-base);
    line-height: 1.65;
    color: var(--c-text);
    background: var(--c-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--ff-display);
    color: var(--c-heading);
    line-height: 1.1;
    font-weight: 600;
    letter-spacing: -0.02em;
    margin: 0 0 var(--s-4);
}
h1 { font-size: clamp(40px, 6vw, 72px); font-weight: 600; letter-spacing: -0.025em; line-height: 1.05; }
h2 { font-size: clamp(30px, 4vw, 48px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.1; }
h3 { font-size: clamp(20px, 2.2vw, 24px); font-weight: 600; letter-spacing: -0.01em; line-height: 1.25; }
h4 { font-size: var(--fs-lg); font-weight: 600; }
h5 { font-size: var(--fs-md); font-weight: 600; }
h6 { font-family: var(--ff-body); font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; }

p { margin: 0 0 var(--s-4); }
a { color: var(--c-secondary); text-decoration: none; transition: color var(--dur) var(--ease); }
a:hover { color: var(--c-accent); }
img, svg { max-width: 100%; height: auto; display: block; }
ul, ol { padding: 0; margin: 0; }

::selection { background: var(--c-accent); color: #fff; }

/* =========================================================
   3. Layout primitives
   ========================================================= */
.r-container {
    max-width: var(--container);
    margin-inline: auto;
    padding-inline: var(--s-6);
}

.r-section { padding-block: var(--section-y); }
.r-section--tight { padding-block: var(--s-16); }
.r-section--alt   { background: var(--c-bg-alt); }
.r-section--soft  { background: var(--c-bg-soft); }
.r-section--dark  {
    background: var(--c-bg-dark);
    color: var(--c-text-inverse);
}
.r-section--dark h1, .r-section--dark h2, .r-section--dark h3, .r-section--dark h4 { color: var(--c-text-inverse); }

/* Section heading block */
.r-heading {
    text-align: center;
    max-width: 760px;
    margin: 0 auto var(--s-16);
}
.r-heading--left { text-align: left; max-width: 920px; margin-left: 0; margin-right: 0; }
.r-heading__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--ff-body);
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--c-accent);
    margin-bottom: var(--s-4);
    padding: 0;
    background: transparent;
    border-radius: 0;
}
.r-heading__eyebrow::before {
    content: '';
    display: inline-block;
    width: 24px;
    height: 2px;
    background: var(--c-accent);
    border-radius: 2px;
}
.r-heading--left .r-heading__eyebrow { justify-content: flex-start; }
.r-heading {  /* override default centered margin for new spec */ }
.r-heading__title { margin-bottom: var(--s-4); }
.r-heading__subtitle {
    color: var(--c-text-light);
    font-size: var(--fs-md);
    margin: 0;
    line-height: 1.6;
}
.r-section--dark .r-heading__subtitle { color: var(--c-text-invert-muted); }
.r-section--dark .r-heading__eyebrow { color: #B794F4; }
.r-section--dark .r-heading__eyebrow::before { background: #B794F4; }

/* Lead text */
.r-lead {
    font-size: var(--fs-md);
    line-height: 1.75;
    color: var(--c-text);
    max-width: 720px;
}

/* =========================================================
   4. Buttons
   ========================================================= */
.r-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    padding: 14px 30px;
    border-radius: var(--rad-pill);
    font-family: var(--ff-heading);
    font-weight: 600;
    font-size: var(--fs-base);
    line-height: 1.2;
    text-decoration: none;
    border: 2px solid transparent;
    cursor: pointer;
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease);
    white-space: nowrap;
}
.r-btn--primary {
    background: var(--g-brand);
    color: var(--c-text-inverse);
    box-shadow: var(--sh-glow);
}
.r-btn--primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh-glow-violet);
    color: var(--c-text-inverse);
}
.r-btn--secondary {
    background: transparent;
    color: var(--c-primary);
    border-color: var(--c-primary);
}
.r-btn--secondary:hover {
    background: var(--c-primary);
    color: #fff;
}
.r-btn--ghost {
    background: rgba(255,255,255,0.10);
    color: #fff;
    border-color: rgba(255,255,255,0.30);
    backdrop-filter: blur(8px);
}
.r-btn--ghost:hover { background: rgba(255,255,255,0.22); color: #fff; }
.r-btn--light {
    background: #fff;
    color: var(--c-primary);
    box-shadow: var(--sh-md);
}
.r-btn--light:hover {
    background: var(--c-primary);
    color: #fff;
}
.r-btn--sm  { padding: 10px 20px; font-size: var(--fs-sm); }
.r-btn--lg  { padding: 18px 38px; font-size: var(--fs-md); }
.r-btn--icon { padding: 12px; }

/* CTA group */
.r-cta-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-4);
    align-items: center;
}

/* Text link with arrow */
.r-link-arrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--c-secondary);
    font-weight: 600;
    font-size: var(--fs-sm);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.r-link-arrow::after {
    content: '→';
    transition: transform var(--dur) var(--ease);
}
.r-link-arrow:hover::after { transform: translateX(4px); }

/* =========================================================
   5. Hero (centered + gradient orb background)
   ========================================================= */
.r-hero {
    position: relative;
    padding-block: calc(var(--s-24) + 96px) var(--s-24);
    background: var(--c-bg-dark);
    color: var(--c-text-inverse);
    overflow: hidden;
    text-align: center;
}
.r-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--g-dark-orb);
    pointer-events: none;
}
.r-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
    background-size: 60px 60px;
    pointer-events: none;
    mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.r-hero > * { position: relative; z-index: 1; }

.r-hero__eyebrow {
    display: inline-block;
    font-size: var(--fs-xs);
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--c-secondary);
    background: rgba(30,136,255,0.14);
    border: 1px solid rgba(30,136,255,0.30);
    padding: 8px 16px;
    border-radius: var(--rad-pill);
    margin-bottom: var(--s-6);
    backdrop-filter: blur(4px);
}
.r-hero h1 {
    color: var(--c-text-inverse);
    font-weight: 800;
    max-width: 920px;
    margin-inline: auto;
    margin-bottom: var(--s-6);
}
.r-hero h1 .text-gradient {
    background: var(--g-brand);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.r-hero__sub {
    font-size: var(--fs-md);
    line-height: 1.7;
    color: rgba(255,255,255,0.78);
    max-width: 680px;
    margin: 0 auto var(--s-10);
}
.r-hero .r-cta-group { justify-content: center; }

/* Inner / page hero (smaller) */
.r-hero--page {
    padding-block: calc(var(--s-16) + 96px) var(--s-16);
    text-align: left;
}
.r-hero--page .r-cta-group { justify-content: flex-start; }
.r-hero--page h1 { margin-inline: 0; }
.r-hero--page .r-hero__sub { margin-inline: 0; }

/* Split hero (copy left, visual right) */
.r-hero--split {
    text-align: left;
    padding-block: calc(var(--s-20) + 96px) var(--s-20);
}
.r-hero--split .r-hero__grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: var(--s-12);
    align-items: center;
}
.r-hero--split .r-hero__eyebrow {
    margin-inline: 0;
}
.r-hero--split h1 {
    margin-inline: 0;
    text-align: left;
    max-width: 640px;
    font-size: clamp(36px, 5vw, 64px);
    line-height: 1.05;
}
.r-hero--split .r-hero__sub {
    margin-inline: 0;
    text-align: left;
    max-width: 560px;
}
.r-hero--split .r-cta-group { justify-content: flex-start; }
.r-hero__visual {
    position: relative;
    width: 100%;
    max-width: 520px;
    margin-left: auto;
    aspect-ratio: 1 / 1;
}
@media (max-width: 960px) {
    .r-hero--split .r-hero__grid { grid-template-columns: 1fr; gap: var(--s-10); }
    .r-hero__visual { max-width: 400px; margin: 0 auto; }
}

/* Trust band — standalone section between hero and stats */
.r-trust-band {
    background: var(--c-ink);
    padding-block: var(--s-10);
    border-top: 1px solid rgba(255,255,255,0.06);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.r-trust-band .r-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--s-5);
}
.r-trust-band .r-trust-strip__label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: rgba(255,255,255,0.45);
}
.r-trust-band .r-trust-strip__logos {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--s-10);
}
.r-trust-logo {
    font-family: var(--ff-display);
    font-weight: 600;
    font-size: 18px;
    letter-spacing: 0.02em;
    color: rgba(255,255,255,0.55);
    transition: color var(--dur) var(--ease);
    cursor: default;
}
.r-trust-logo:hover { color: rgba(255,255,255,0.95); }
@media (max-width: 768px) {
    .r-trust-band .r-trust-strip__logos { gap: var(--s-6); }
    .r-trust-logo { font-size: 16px; }
}

/* Inline hero metrics (case study heroes) */
.r-hero__metrics {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-10);
    margin-top: var(--s-10);
    padding-top: var(--s-8);
    border-top: 1px solid rgba(255,255,255,0.10);
}
.r-hero__metric { min-width: 140px; }
.r-hero__metric-value {
    font-family: var(--ff-display);
    font-size: clamp(36px, 4.5vw, 56px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.03em;
    background: linear-gradient(135deg, #60A8FF 0%, #B794F4 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 6px;
}
.r-hero__metric-label {
    font-family: var(--ff-body);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: rgba(255,255,255,0.65);
}

/* Trust strip below hero */
.r-trust-strip {
    margin-top: var(--s-12);
    padding-top: var(--s-8);
    border-top: 1px solid rgba(255,255,255,0.10);
    text-align: center;
}
.r-trust-strip__label {
    font-size: var(--fs-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: rgba(255,255,255,0.55);
    margin-bottom: var(--s-4);
}
.r-trust-strip__logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-10);
    opacity: 0.7;
    filter: grayscale(1) brightness(2);
}

/* =========================================================
   6. Breadcrumbs
   ========================================================= */
.r-breadcrumbs ol {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    list-style: none;
    font-family: var(--ff-body);
    font-size: 13px;
    font-weight: 500;
    color: rgba(255,255,255,0.65);
    margin: 0 0 var(--s-6);
    padding: 0;
}
.r-breadcrumbs li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.r-breadcrumbs li:not(:last-child)::after {
    content: '›';
    margin-left: 6px;
    opacity: 0.6;
    font-size: 14px;
}
.r-breadcrumbs a {
    color: rgba(255,255,255,0.78);
    padding: 4px 10px;
    border-radius: var(--rad-pill);
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    transition: all var(--dur) var(--ease);
}
.r-breadcrumbs a:hover {
    color: #fff;
    background: rgba(255,255,255,0.10);
    border-color: rgba(255,255,255,0.18);
}
.r-breadcrumbs li[aria-current] {
    color: #fff;
    padding: 4px 10px;
    border-radius: var(--rad-pill);
    background: rgba(30,136,255,0.18);
    border: 1px solid rgba(30,136,255,0.30);
}

/* Light breadcrumb variant */
.r-section .r-breadcrumbs ol { color: var(--c-text-light); }
.r-section .r-breadcrumbs a { color: var(--c-text-light); }
.r-section .r-breadcrumbs a:hover { color: var(--c-secondary); }

/* =========================================================
   7. Cards
   ========================================================= */
.r-card {
    background: var(--c-bg);
    border: 1px solid var(--c-border);
    border-radius: var(--rad-xl);
    padding: var(--s-8);
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
    display: flex;
    flex-direction: column;
    gap: var(--s-4);
    height: 100%;
    text-decoration: none;
    color: inherit;
    position: relative;
    overflow: hidden;
}
.r-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--sh-lg);
    border-color: transparent;
    color: inherit;
}
.r-card--feature {
    padding: var(--s-10);
}
.r-card--feature::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--g-brand);
    opacity: 0;
    transition: opacity var(--dur) var(--ease);
    pointer-events: none;
    border-radius: inherit;
}
.r-card--feature:hover::before { opacity: 0.04; }

.r-card__icon {
    width: 56px;
    height: 56px;
    border-radius: var(--rad-lg);
    background: var(--g-brand);
    color: var(--c-text-inverse);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    flex-shrink: 0;
    box-shadow: var(--sh-glow);
}
.r-card__icon--soft {
    background: var(--g-brand-soft);
    color: var(--c-secondary);
    box-shadow: none;
}
.r-card__title {
    font-size: var(--fs-lg);
    font-weight: 700;
    color: var(--c-heading);
    margin: 0;
}
.r-card__tagline {
    color: var(--c-secondary);
    font-weight: 600;
    font-size: var(--fs-sm);
    margin: 0;
}
.r-card__desc {
    color: var(--c-text);
    font-size: var(--fs-sm);
    line-height: 1.65;
    margin: 0;
}
.r-card__meta {
    display: flex;
    gap: var(--s-3);
    flex-wrap: wrap;
    font-size: var(--fs-xs);
    color: var(--c-text-light);
    margin-top: auto;
}
.r-card__cta {
    margin-top: auto;
    color: var(--c-secondary);
    font-weight: 600;
    font-size: var(--fs-sm);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.r-card__cta::after { content: ' →'; display: inline-block; transition: transform var(--dur) var(--ease); }
.r-card:hover .r-card__cta::after { transform: translateX(4px); }

/* =========================================================
   8. Grid utilities
   ========================================================= */
.r-grid { display: grid; gap: var(--s-6); }
.r-grid--1 { grid-template-columns: 1fr; max-width: 760px; margin: 0 auto; }
.r-grid--2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.r-grid--3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.r-grid--4 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.r-grid--5 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.r-grid--12 { grid-template-columns: repeat(12, 1fr); }

/* Article body (blog single + case study full story) */
.r-article {
    max-width: 760px;
    margin: 0 auto;
    font-family: var(--ff-body);
    font-size: 18px;
    line-height: 1.75;
    color: var(--c-text);
}
.r-article p { margin: 0 0 var(--s-5); }
.r-article h2 {
    font-family: var(--ff-display);
    font-size: clamp(26px, 3vw, 34px);
    margin-top: var(--s-10);
    margin-bottom: var(--s-4);
    color: var(--c-heading);
}
.r-article h3 {
    font-family: var(--ff-display);
    font-size: 22px;
    margin-top: var(--s-8);
    margin-bottom: var(--s-3);
    color: var(--c-heading);
}
.r-article ul, .r-article ol {
    padding-left: var(--s-6);
    margin: 0 0 var(--s-5);
}
.r-article li { margin-bottom: var(--s-2); }
.r-article a { color: var(--c-secondary); border-bottom: 1px solid rgba(30,136,255,0.3); }
.r-article a:hover { color: var(--c-accent); border-bottom-color: var(--c-accent); }
.r-article blockquote {
    margin: var(--s-8) 0;
    padding: var(--s-2) 0 var(--s-2) var(--s-6);
    border-left: 3px solid var(--c-accent);
    font-family: var(--ff-display);
    font-size: 22px;
    line-height: 1.5;
    color: var(--c-heading);
    font-style: normal;
}
.r-article code {
    background: var(--c-bg-alt);
    padding: 2px 8px;
    border-radius: 4px;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.9em;
    color: var(--c-primary);
}
.r-article pre {
    background: var(--c-ink);
    color: #fff;
    padding: var(--s-5) var(--s-6);
    border-radius: var(--rad-lg);
    overflow-x: auto;
    margin: var(--s-6) 0;
}
.r-article pre code { background: transparent; color: inherit; padding: 0; }
.r-article img {
    border-radius: var(--rad-lg);
    margin: var(--s-6) 0;
}

/* Article meta line (under blog post H1) */
.r-article__meta {
    display: inline-flex;
    align-items: center;
    gap: var(--s-3);
    font-family: var(--ff-body);
    font-size: 14px;
    color: rgba(255,255,255,0.65);
}
.r-article__meta-dot { opacity: 0.5; }

/* 404 — big gradient code with copy below */
.r-404 { text-align: center; max-width: 720px; margin: 0 auto; }
.r-404__code {
    font-family: var(--ff-display);
    font-weight: 700;
    font-size: clamp(120px, 18vw, 200px);
    line-height: 0.9;
    letter-spacing: -0.05em;
    background: linear-gradient(135deg, #60A8FF 0%, #B794F4 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: var(--s-6);
}
.r-hero--404 { text-align: center; }
.r-hero--404 .r-cta-group { justify-content: center; }

/* Empty state — used on blog index / case studies when no posts */
.r-empty-state {
    text-align: center;
    padding: var(--s-16) var(--s-6);
    max-width: 540px;
    margin: 0 auto;
}
.r-empty-state h3 {
    font-family: var(--ff-display);
    font-size: 28px;
    color: var(--c-heading);
    margin-bottom: var(--s-3);
}
.r-empty-state p { color: var(--c-text-light); margin-bottom: var(--s-6); }

/* Comparison table */
.r-compare-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.r-compare-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--rad-lg);
    overflow: hidden;
    font-size: var(--fs-sm);
}
.r-compare-table thead th {
    background: var(--c-ink);
    color: #fff;
    text-align: left;
    padding: var(--s-4) var(--s-5);
    font-family: var(--ff-display);
    font-weight: 600;
    font-size: 14px;
    letter-spacing: -0.01em;
    border: none;
}
.r-compare-table tbody td {
    padding: var(--s-4) var(--s-5);
    border-top: 1px solid var(--c-border);
    vertical-align: top;
    color: var(--c-text);
    line-height: 1.55;
}
.r-compare-table tbody tr:nth-child(even) td {
    background: var(--c-bg-alt);
}
.r-compare-table tbody td:first-child {
    color: var(--c-text-strong);
    width: 28%;
    min-width: 160px;
}
.r-compare-table tbody td:not(:first-child) {
    width: 36%;
}
@media (max-width: 700px) {
    .r-compare-table { font-size: 13px; }
    .r-compare-table thead th,
    .r-compare-table tbody td { padding: var(--s-3) var(--s-4); }
}

/* Book-a-call layout */
.r-book-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: var(--s-10);
    align-items: start;
}
@media (max-width: 960px) {
    .r-book-grid { grid-template-columns: 1fr; }
}
.r-calendly-placeholder {
    background: #fff;
    border: 2px dashed var(--c-border-strong);
    border-radius: var(--rad-xl);
    padding: var(--s-12);
    text-align: center;
    min-height: 600px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    color: var(--c-text-light);
}

/* Live Calendly embed: clean white card framing */
.r-calendly-embed {
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--rad-xl);
    padding: var(--s-3);
    overflow: hidden;
    box-shadow: var(--sh-md);
}
.r-calendly-embed .calendly-inline-widget {
    border-radius: var(--rad-lg);
    overflow: hidden;
}
.r-calendly-placeholder svg { color: var(--c-secondary); margin-bottom: var(--s-4); }
.r-calendly-placeholder h3 { color: var(--c-heading); margin-bottom: var(--s-4); }
.r-calendly-placeholder p { max-width: 480px; margin: 0 auto var(--s-4); }
.r-calendly-placeholder code {
    display: block;
    background: var(--c-bg-alt);
    border: 1px solid var(--c-border);
    border-radius: var(--rad-md);
    padding: var(--s-3) var(--s-4);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 12px;
    color: var(--c-primary);
    max-width: 580px;
    margin: 0 auto;
    text-align: left;
    word-break: break-all;
}

/* Accent card (soft gradient background, no border) */
.r-card--accent {
    background: var(--g-brand-soft);
    border-color: transparent;
}
.r-card--accent .r-card__title { color: var(--c-primary); margin-bottom: var(--s-3); }

/* Pricing card */
.r-pricing-card { position: relative; padding: var(--s-8); gap: var(--s-3); }
.r-pricing-card--featured {
    border: 2px solid var(--c-secondary);
    box-shadow: 0 20px 40px -16px rgba(30,136,255,0.20);
}
.r-pricing-card__badge {
    position: absolute;
    top: -14px;
    left: var(--s-8);
    background: var(--g-brand);
    color: #fff;
    font-family: var(--ff-body);
    font-size: 11px;
    font-weight: 700;
    padding: 6px 14px;
    border-radius: var(--rad-pill);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
.r-pricing-card__name {
    font-family: var(--ff-display);
    font-size: 26px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--c-heading);
    margin: 0;
}
.r-pricing-card__price {
    font-family: var(--ff-display);
    font-weight: 600;
    color: var(--c-secondary);
    font-size: 17px;
    margin: 0;
}
.r-pricing-card__divider {
    border-top: 1px solid var(--c-border);
    margin: var(--s-2) 0;
}
.r-pricing-card__fit-label {
    font-family: var(--ff-body);
    font-size: 12px;
    color: var(--c-text-light);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-weight: 600;
}
.r-pricing-card__list { margin-top: var(--s-2); }
.r-pricing-card .r-btn { margin-top: auto; }

/* Team card avatar */
.r-team-card__avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: var(--g-brand);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-family: var(--ff-display);
    font-weight: 700;
    font-size: 28px;
    box-shadow: var(--sh-md);
}

/* Pull-quote testimonial card */
.r-quote-card {
    background: var(--c-bg);
    border: 1px solid var(--c-border);
    border-radius: var(--rad-xl);
    padding: var(--s-8);
    display: flex;
    flex-direction: column;
    gap: var(--s-4);
    position: relative;
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.r-quote-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sh-lg);
    border-color: var(--c-secondary);
}
.r-section--alt .r-quote-card { background: #fff; }
.r-quote-card__mark {
    font-family: var(--ff-display);
    font-size: 56px;
    font-weight: 700;
    color: var(--c-accent);
    line-height: 0.8;
    margin-top: -8px;
}
.r-quote-card__quote {
    font-family: var(--ff-display);
    font-size: 20px;
    line-height: 1.4;
    color: var(--c-text-strong);
    font-weight: 500;
    letter-spacing: -0.01em;
    margin: 0;
}
.r-quote-card__author {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: auto;
    padding-top: var(--s-4);
    border-top: 1px solid var(--c-border);
}
.r-quote-card__author strong {
    font-family: var(--ff-body);
    color: var(--c-primary);
    font-weight: 600;
}
.r-quote-card__author span {
    font-size: 14px;
    color: var(--c-text-light);
}

.r-grid--split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-10);
    align-items: start;
}
@media (max-width: 900px) { .r-grid--split { grid-template-columns: 1fr; } }

/* =========================================================
   9. Stats
   ========================================================= */
.r-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--s-8);
    text-align: center;
}
.r-stats > div {
    position: relative;
    padding-inline: var(--s-4);
}
.r-stats > div + div::before {
    content: '';
    position: absolute;
    left: 0;
    top: 10%;
    bottom: 10%;
    width: 1px;
    background: var(--c-border);
}
.r-section--dark .r-stats > div + div::before { background: var(--c-border-dark); }
@media (max-width: 768px) {
    .r-stats > div + div::before { display: none; }
}
.r-stat__value {
    font-family: var(--ff-display);
    font-size: clamp(44px, 6vw, 72px);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.03em;
    margin-bottom: var(--s-3);
    background: var(--g-brand);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.r-section--dark .r-stat__value {
    background: linear-gradient(135deg, #60A8FF 0%, #B794F4 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.r-stat__label {
    font-family: var(--ff-body);
    font-size: 13px;
    color: var(--c-text-light);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-weight: 600;
}
.r-section--dark .r-stat__label { color: var(--c-text-invert-muted); }

/* =========================================================
   10. Process
   ========================================================= */
.r-process { display: grid; gap: var(--s-10); position: relative; }
.r-process__item {
    display: grid;
    grid-template-columns: 96px 1fr;
    gap: var(--s-6);
    align-items: start;
    position: relative;
}
.r-process__item:not(:last-child)::before {
    content: '';
    position: absolute;
    top: 72px;
    left: 48px;
    bottom: -48px;
    width: 1px;
    background: linear-gradient(180deg, rgba(124,58,237,0.4), transparent);
}
.r-section--dark .r-process__item:not(:last-child)::before {
    background: linear-gradient(180deg, rgba(183,148,244,0.4), transparent);
}
.r-process__num {
    width: 96px;
    height: 96px;
    background: transparent;
    color: transparent;
    font-family: var(--ff-display);
    font-weight: 700;
    font-size: 64px;
    line-height: 1;
    letter-spacing: -0.04em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: none;
    border-radius: 0;
    position: relative;
    z-index: 1;
    background-image: var(--g-brand);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.r-section--dark .r-process__num {
    background-image: linear-gradient(135deg, #60A8FF 0%, #B794F4 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.r-process__title {
    font-size: var(--fs-lg);
    font-weight: 700;
    color: var(--c-heading);
    margin: 0 0 var(--s-2);
}

/* =========================================================
   11. FAQ
   ========================================================= */
.r-faqs { display: grid; gap: 0; border-top: 1px solid var(--c-border); }
.r-faq {
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--c-border);
    border-radius: 0;
    padding: var(--s-6) 0;
    transition: none;
}
.r-faq:hover { border-color: var(--c-border); }
.r-faq[open] {
    border-color: var(--c-border);
    box-shadow: none;
    background: transparent;
}
.r-faq summary {
    cursor: pointer;
    font-family: var(--ff-display);
    font-weight: 600;
    color: var(--c-heading);
    font-size: 18px;
    line-height: 1.4;
    letter-spacing: -0.01em;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--s-4);
    padding-right: var(--s-2);
}
.r-faq summary::-webkit-details-marker { display: none; }
.r-faq summary::after {
    content: '';
    width: 14px;
    height: 14px;
    border-right: 2px solid var(--c-accent);
    border-bottom: 2px solid var(--c-accent);
    transform: rotate(45deg);
    transition: transform var(--dur) var(--ease);
    flex-shrink: 0;
    margin-top: -4px;
}
.r-faq[open] summary::after { transform: rotate(-135deg); margin-top: 2px; }
.r-faq__answer {
    margin-top: var(--s-4);
    padding-top: 0;
    border-top: none;
    color: var(--c-text);
    line-height: 1.7;
    font-size: var(--fs-base);
    max-width: 720px;
}

/* =========================================================
   12. CTA band
   ========================================================= */
.r-cta-band {
    background: var(--c-ink);
    color: var(--c-text-inverse);
    padding-block: var(--s-24);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.r-cta-band::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 15% 20%, rgba(30,136,255,0.30), transparent 45%),
        radial-gradient(circle at 85% 80%, rgba(124,58,237,0.30), transparent 45%);
    pointer-events: none;
}
.r-cta-band::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
    background-size: 60px 60px;
    pointer-events: none;
    mask-image: radial-gradient(ellipse at center, black 25%, transparent 75%);
}
.r-cta-band > * { position: relative; z-index: 1; }
.r-cta-band h2 {
    color: #fff;
    font-weight: 600;
    margin-bottom: var(--s-4);
    max-width: 820px;
    margin-inline: auto;
}
.r-cta-band p {
    color: var(--c-text-invert-muted);
    font-size: var(--fs-md);
    line-height: 1.6;
    margin-bottom: var(--s-10);
    max-width: 640px;
    margin-inline: auto;
}
.r-cta-band .r-cta-group { justify-content: center; }

/* =========================================================
   13. List with check icons
   ========================================================= */
.r-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--s-3);
}
.r-list li {
    padding-left: 36px;
    position: relative;
    color: var(--c-text);
    line-height: 1.6;
    font-size: var(--fs-base);
}
.r-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 2px;
    width: 24px;
    height: 24px;
    background: var(--g-brand);
    color: white;
    border-radius: 50%;
    font-size: 13px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.r-list--inline {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-2);
}
.r-list--inline li {
    padding: 6px 14px;
    background: var(--g-brand-soft);
    color: var(--c-primary);
    border-radius: var(--rad-pill);
    font-size: var(--fs-sm);
    font-weight: 500;
}
.r-list--inline li::before { display: none; }

/* =========================================================
   14. Tagline strip
   ========================================================= */
.r-tagline {
    display: inline-flex;
    gap: var(--s-3);
    font-family: var(--ff-heading);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.20em;
    font-size: var(--fs-xs);
}
.r-tagline span:nth-child(1) { color: var(--c-accent); }
.r-tagline span:nth-child(2) { color: var(--c-secondary); }
.r-tagline span:nth-child(3) { color: var(--c-primary); }

/* =========================================================
   15. Logo (text placeholder)
   ========================================================= */
/* =========================================================
   15. Logo
   ========================================================= */
.r-logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    font-family: var(--ff-display);
    line-height: 1;
}
.r-logo__mark {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: var(--g-brand);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-family: var(--ff-display);
    font-weight: 700;
    font-size: 17px;
    letter-spacing: -0.02em;
    box-shadow: 0 4px 14px -4px rgba(30,136,255,0.4);
    flex-shrink: 0;
}
.r-logo__text {
    display: inline-flex;
    flex-direction: column;
    gap: 3px;
    line-height: 1;
}
.r-logo__name {
    font-family: var(--ff-display);
    font-weight: 600;
    font-size: 19px;
    color: var(--c-primary);
    letter-spacing: -0.02em;
}
.r-logo__name span { color: var(--c-secondary); font-weight: 600; }
.r-logo__tag {
    font-family: var(--ff-body);
    font-size: 10px;
    font-weight: 500;
    color: var(--c-text-light);
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

/* Hide tagline on small screens to keep header compact */
@media (max-width: 600px) {
    .r-logo__tag { display: none; }
}

/* =========================================================
   16. Header / nav
   ========================================================= */
.r-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: transparent;
    border-bottom: 1px solid transparent;
    transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), backdrop-filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.r-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: 18px;
    gap: var(--s-6);
    transition: padding var(--dur) var(--ease);
}
.r-header.is-scrolled {
    background: rgba(255,255,255,0.95);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom-color: var(--c-border);
    box-shadow: 0 1px 0 rgba(10,26,62,0.03);
}
.r-header.is-scrolled .r-header__inner { padding-block: 12px; }

/* Dark-hero default: white logo + nav, soft tagline */
.r-header .r-logo__name { color: #fff; transition: color var(--dur); }
.r-header .r-logo__name span { color: #B794F4; }
.r-header .r-logo__tag { color: rgba(255,255,255,0.55); transition: color var(--dur); }
.r-header.is-scrolled .r-logo__name { color: var(--c-primary); }
.r-header.is-scrolled .r-logo__name span { color: var(--c-secondary); }
.r-header.is-scrolled .r-logo__tag { color: var(--c-text-light); }

.r-nav {
    display: flex;
    align-items: center;
    gap: var(--s-6);
}
.r-nav__list {
    display: flex;
    list-style: none;
    gap: var(--s-6);
    margin: 0;
    padding: 0;
}
.r-nav__list a {
    color: rgba(255,255,255,0.85);
    font-family: var(--ff-body);
    font-weight: 500;
    font-size: 14.5px;
    padding: 8px 0;
    position: relative;
    transition: color var(--dur) var(--ease);
    letter-spacing: -0.005em;
}
.r-nav__list a:hover { color: #fff; }
.r-header.is-scrolled .r-nav__list a { color: var(--c-text); }
.r-header.is-scrolled .r-nav__list a:hover { color: var(--c-secondary); }

/* Hover underline */
.r-nav__list a::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    height: 2px;
    background: var(--c-secondary);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--dur) var(--ease);
    border-radius: 1px;
}
.r-nav__list a:hover::after { transform: scaleX(1); }

/* Active page — permanent indicator */
.r-nav__list a.is-active {
    color: #fff;
    font-weight: 600;
}
.r-header.is-scrolled .r-nav__list a.is-active { color: var(--c-secondary); }
.r-nav__list a.is-active::after {
    transform: scaleX(1);
    background: var(--c-secondary);
}

/* Book a Call button: a little tighter for nav use */
.r-header .r-btn--sm {
    padding: 9px 18px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: -0.005em;
    border-radius: var(--rad-pill);
}

/* Mobile nav toggle */
.r-nav__toggle {
    display: none;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    border: none;
    background: rgba(255,255,255,0.08);
    cursor: pointer;
    color: #fff;
    transition: background var(--dur) var(--ease);
}
.r-nav__toggle:hover { background: rgba(255,255,255,0.16); }
.r-header.is-scrolled .r-nav__toggle {
    color: var(--c-primary);
    background: var(--c-bg-alt);
}
.r-header.is-scrolled .r-nav__toggle:hover { background: var(--c-bg-soft); }

@media (max-width: 900px) {
    .r-header__inner { padding-block: 14px; }
    .r-nav { gap: var(--s-3); }
    .r-nav__list { display: none; }
    .r-nav > .r-btn { display: none; }
    .r-nav__toggle { display: inline-flex; align-items: center; justify-content: center; }
    .r-nav.is-open .r-nav__list {
        display: flex;
        flex-direction: column;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: #fff;
        padding: var(--s-4) var(--s-6) var(--s-6);
        box-shadow: 0 10px 30px -10px rgba(10,26,62,0.15);
        gap: 0;
        border-top: 1px solid var(--c-border);
    }
    .r-nav.is-open .r-nav__list li {
        border-bottom: 1px solid var(--c-border);
    }
    .r-nav.is-open .r-nav__list li:last-child { border-bottom: none; }
    .r-nav.is-open .r-nav__list a {
        display: block;
        color: var(--c-text-strong);
        padding: 14px 0;
        font-size: 16px;
        font-weight: 500;
    }
    .r-nav.is-open .r-nav__list a::after { display: none; }
    .r-nav.is-open .r-nav__list a.is-active { color: var(--c-secondary); font-weight: 600; }
    .r-nav.is-open > .r-btn {
        display: inline-flex;
        position: absolute;
        top: 100%;
        left: var(--s-6);
        right: var(--s-6);
        margin-top: calc(var(--s-6) + (5 * 48px) + var(--s-4));
        justify-content: center;
    }
}

/* Body needs top padding equal to header height since it's now fixed.
   Most pages start with a dark hero — header overlays it transparently. */
body { padding-top: 0; }
main { position: relative; z-index: 1; }

/* =========================================================
   17. Footer
   ========================================================= */
.r-footer {
    background: var(--c-bg-dark);
    color: rgba(255,255,255,0.78);
    padding-block: var(--s-20) var(--s-8);
    position: relative;
}
.r-footer::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 10% 0%, rgba(124,58,237,0.10), transparent 40%),
        radial-gradient(circle at 90% 100%, rgba(30,136,255,0.10), transparent 40%);
    pointer-events: none;
}
.r-footer > * { position: relative; z-index: 1; }
.r-footer a { color: rgba(255,255,255,0.78); transition: color var(--dur); }
.r-footer a:hover { color: var(--c-secondary); }
.r-footer h4 {
    color: #fff;
    font-size: var(--fs-sm);
    margin-bottom: var(--s-5);
    text-transform: uppercase;
    letter-spacing: 0.10em;
    font-weight: 700;
}
.r-footer__top {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: var(--s-10);
    margin-bottom: var(--s-16);
}
.r-footer__brand .r-logo__name { color: #fff; }
.r-footer__brand .r-logo__name span { color: var(--c-secondary); }
.r-footer__about {
    color: rgba(255,255,255,0.70);
    line-height: 1.65;
    margin: var(--s-4) 0;
    font-size: var(--fs-sm);
}
.r-footer__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--s-3);
    font-size: var(--fs-sm);
}
.r-footer__bottom {
    border-top: 1px solid rgba(255,255,255,0.10);
    padding-top: var(--s-6);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: var(--s-4);
    font-size: var(--fs-sm);
    color: rgba(255,255,255,0.55);
}
.r-footer__legal {
    display: flex;
    gap: var(--s-5);
    list-style: none;
}
.r-social {
    display: flex;
    gap: var(--s-3);
    margin-top: var(--s-4);
}
.r-social a {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background var(--dur), transform var(--dur);
}
.r-social a:hover {
    background: var(--g-brand);
    transform: translateY(-3px);
}

@media (max-width: 768px) {
    .r-footer__top { grid-template-columns: 1fr 1fr; }
    .r-footer__brand { grid-column: span 2; }
}

/* =========================================================
   18. Forms
   ========================================================= */
.r-form { display: grid; gap: var(--s-4); }
.r-form__field { display: grid; gap: var(--s-2); }
.r-form__label {
    font-size: var(--fs-sm);
    font-weight: 600;
    color: var(--c-text-strong);
}
.r-form__input,
.r-form__textarea {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--c-border);
    border-radius: var(--rad-md);
    font-family: var(--ff-body);
    font-size: var(--fs-base);
    color: var(--c-text-strong);
    background: var(--c-bg);
    transition: border-color var(--dur), box-shadow var(--dur);
}
.r-form__input:focus,
.r-form__textarea:focus {
    outline: none;
    border-color: var(--c-secondary);
    box-shadow: 0 0 0 3px rgba(30,136,255,0.18);
}
.r-form__hint {
    font-size: 13px;
    color: var(--c-text-light);
    margin: var(--s-4) 0 0;
    line-height: 1.5;
}

/* =========================================================
   18b. Contact Form 7 — overrides to match Direction B
   ========================================================= */
.r-form-wrap .wpcf7 { margin: 0; }
.r-form-wrap .wpcf7-form { display: grid; gap: var(--s-4); }

/* Our own .r-form__field wrapper takes care of label + spacing.
   CF7 wraps inputs in <span class="wpcf7-form-control-wrap">, which
   we just let flow inline (no extra block-level spacing). */
.r-form-wrap .wpcf7-form-control-wrap { display: block; }
.r-form-wrap .r-form__required { color: var(--c-secondary); font-weight: 600; }

.r-form-wrap input[type="text"],
.r-form-wrap input[type="email"],
.r-form-wrap input[type="tel"],
.r-form-wrap input[type="url"],
.r-form-wrap select,
.r-form-wrap textarea {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--c-border);
    border-radius: var(--rad-md);
    font-family: var(--ff-body);
    font-size: var(--fs-base);
    color: var(--c-text-strong);
    background: var(--c-bg);
    box-shadow: none;
    transition: border-color var(--dur), box-shadow var(--dur);
    max-width: 100%;
    line-height: 1.4;
}
.r-form-wrap select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%235B6478' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 44px;
}
.r-form-wrap input:focus,
.r-form-wrap select:focus,
.r-form-wrap textarea:focus {
    outline: none;
    border-color: var(--c-secondary);
    box-shadow: 0 0 0 3px rgba(30,136,255,0.18);
}
.r-form-wrap textarea { min-height: 120px; resize: vertical; }

/* Acceptance / consent checkbox */
.r-form-wrap .r-form__field--check { display: flex; align-items: flex-start; gap: var(--s-3); }
.r-form-wrap .wpcf7-acceptance { display: block; }
.r-form-wrap .wpcf7-acceptance .wpcf7-list-item { margin: 0; display: flex; align-items: flex-start; gap: 10px; }
.r-form-wrap .wpcf7-acceptance .wpcf7-list-item-label {
    font-family: var(--ff-body);
    font-size: 13px;
    color: var(--c-text-light);
    line-height: 1.5;
}
.r-form-wrap input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 2px 0 0;
    accent-color: var(--c-secondary);
    flex-shrink: 0;
}

/* Submit button — Direction B pill */
.r-form-wrap input[type="submit"].wpcf7-submit,
.r-form-wrap button[type="submit"].wpcf7-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    padding: 14px 30px;
    border-radius: var(--rad-pill);
    font-family: var(--ff-body);
    font-weight: 600;
    font-size: var(--fs-base);
    line-height: 1.2;
    background: var(--g-brand);
    color: #fff;
    border: none;
    box-shadow: var(--sh-glow);
    cursor: pointer;
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
    width: auto;
    align-self: flex-start;
}
.r-form-wrap .wpcf7-submit:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh-glow-violet);
    color: #fff;
}
.r-form-wrap .wpcf7-spinner { margin-left: var(--s-3); align-self: center; }

/* CF7 response messages (validation + success + spam) */
.r-form-wrap .wpcf7-response-output {
    margin: var(--s-3) 0 0 !important;
    padding: var(--s-4) var(--s-5) !important;
    border-radius: var(--rad-md) !important;
    border-width: 1px !important;
    font-size: 14px;
    line-height: 1.5;
}
.r-form-wrap .wpcf7 form.sent .wpcf7-response-output {
    background: rgba(16,185,129,0.08);
    border-color: rgba(16,185,129,0.30) !important;
    color: var(--c-text-strong);
}
.r-form-wrap .wpcf7 form.invalid .wpcf7-response-output,
.r-form-wrap .wpcf7 form.unaccepted .wpcf7-response-output,
.r-form-wrap .wpcf7 form.payment-required .wpcf7-response-output {
    background: rgba(245,158,11,0.08);
    border-color: rgba(245,158,11,0.35) !important;
    color: var(--c-text-strong);
}
.r-form-wrap .wpcf7 form.failed .wpcf7-response-output,
.r-form-wrap .wpcf7 form.aborted .wpcf7-response-output,
.r-form-wrap .wpcf7 form.spam .wpcf7-response-output {
    background: rgba(239,68,68,0.08);
    border-color: rgba(239,68,68,0.30) !important;
    color: var(--c-danger);
}

/* Inline validation tips */
.r-form-wrap .wpcf7-not-valid-tip {
    color: var(--c-danger) !important;
    font-size: 13px !important;
    margin-top: 4px;
    font-weight: 500;
}
.r-form-wrap .wpcf7-not-valid {
    border-color: var(--c-danger) !important;
}

/* Hide CF7's autogenerated <p> wrappers (we use .r-form__field instead) */
.r-form-wrap .wpcf7-form p { margin: 0; }

/* =========================================================
   19. Quick facts bar
   ========================================================= */
.r-facts-bar {
    background: var(--g-brand-soft);
    border-radius: var(--rad-xl);
    padding: var(--s-8);
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--s-6);
}
.r-fact h6 {
    font-size: var(--fs-xs);
    color: var(--c-primary);
    margin-bottom: var(--s-2);
    letter-spacing: 0.10em;
}
.r-fact p {
    font-size: var(--fs-sm);
    color: var(--c-text);
    margin: 0;
    line-height: 1.5;
}

/* =========================================================
   20. Pill badge / tag
   ========================================================= */
.r-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    background: var(--g-brand-soft);
    color: var(--c-primary);
    border-radius: var(--rad-pill);
    font-size: var(--fs-xs);
    font-weight: 600;
}
.r-badge--success { background: rgba(16,185,129,0.12); color: var(--c-success); }
.r-badge--warning { background: rgba(245,158,11,0.12); color: var(--c-warning); }

/* =========================================================
   21. Tabs
   ========================================================= */
.r-tabs { }
.r-tabs__list {
    display: flex;
    gap: var(--s-2);
    border-bottom: 1px solid var(--c-border);
    margin-bottom: var(--s-8);
    overflow-x: auto;
}
.r-tabs__tab {
    padding: var(--s-3) var(--s-5);
    font-weight: 600;
    color: var(--c-text-light);
    cursor: pointer;
    border: none;
    background: transparent;
    border-bottom: 2px solid transparent;
    transition: color var(--dur), border-color var(--dur);
    white-space: nowrap;
}
.r-tabs__tab.is-active {
    color: var(--c-secondary);
    border-bottom-color: var(--c-secondary);
}

/* =========================================================
   22. Utilities
   ========================================================= */
.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-gradient {
    background: var(--g-brand);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.mb-0 { margin-bottom: 0 !important; }
.mb-2 { margin-bottom: var(--s-2); }
.mb-4 { margin-bottom: var(--s-4); }
.mb-6 { margin-bottom: var(--s-6); }
.mb-8 { margin-bottom: var(--s-8); }
.mt-4 { margin-top: var(--s-4); }
.mt-8 { margin-top: var(--s-8); }
.flex { display: flex; }
.gap-4 { gap: var(--s-4); }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }

/* =========================================================
   23. Responsive
   ========================================================= */
@media (max-width: 1024px) {
    :root { --section-y: var(--s-20); }
}
@media (max-width: 768px) {
    :root {
        --section-y: var(--s-16);
        --fs-base: 15px;
    }
    .r-hero { padding-block: var(--s-20) var(--s-16); }
    .r-process__item { grid-template-columns: 1fr; }
    .r-process__item:not(:last-child)::before { display: none; }
    .r-btn { padding: 12px 22px; }
    h1 { font-size: 36px; }
    h2 { font-size: 28px; }
}

/* =========================================================
   24. WP / GeneratePress overrides
   ========================================================= */
body.revoraops-clean .site-header { display: none; }
body.revoraops-clean #masthead    { display: none; }
body.revoraops-clean .site-info   { display: none; }
body.revoraops-clean #colophon    { display: none; }
body.revoraops-clean .entry-header { display: none; }

.entry-content { font-size: var(--fs-base); }

/* Hide GeneratePress default footer when our footer renders */
body.revoraops-themed .site-footer:not(.r-footer) { display: none; }

/* Animations */
@keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.fade-up { animation: fadeUp 0.6s var(--ease-out) both; }
.fade-up-delay-1 { animation-delay: 0.1s; }
.fade-up-delay-2 { animation-delay: 0.2s; }
.fade-up-delay-3 { animation-delay: 0.3s; }

/* Reveal-on-scroll (driven by IntersectionObserver in revoraops.js) */
.reveal {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 480ms var(--ease-out), transform 480ms var(--ease-out);
}
.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
    .fade-up { animation: none; }
}
