/* ==========================================================================
   Recterior Theme Styles
   Dark architecture/interior design theme
   ========================================================================== */

/* ==========================================================================
   CSS Custom Properties
   ========================================================================== */
:root {
    --recterior-accent: #AC8C66;
    --recterior-accent-contrast: #121B1D;
    --recterior-accent-2: #8CA68C;
    --recterior-bg: #121B1D;
    --recterior-bg-light: #1a2628;
    --recterior-bg-card: #1e2d30;
    --recterior-text: #c5c5c5;
    --recterior-text-muted: #9d9d9d;
    --recterior-heading-color: #ffffff;
    --recterior-white: #ffffff;
    --recterior-border: rgba(255, 255, 255, 0.1);
    /* Semantic foreground tokens (default: dark mode). */
    --recterior-ui-foreground: rgba(255, 255, 255, 0.75);
    --recterior-ui-foreground-hover: #ffffff;
    --recterior-ui-foreground-muted: rgba(255, 255, 255, 0.5);
    --recterior-header-foreground: var(--recterior-ui-foreground);
    --recterior-header-foreground-hover: var(--recterior-ui-foreground-hover);
    --recterior-header-sticky-foreground: var(--recterior-header-foreground);
    --recterior-header-sticky-foreground-hover: var(--recterior-header-foreground-hover);
    --recterior-header-trigger-foreground: var(--recterior-header-foreground);
    --recterior-header-trigger-sticky-foreground: var(--recterior-header-sticky-foreground);
    --recterior-header-dropdown-bg: var(--recterior-bg-light);
    --recterior-header-dropdown-text: rgba(255, 255, 255, 0.7);
    --recterior-header-dropdown-hover-text: #ffffff;
    --recterior-header-dropdown-hover-bg: rgba(172, 140, 102, 0.15);
    --recterior-header-sticky-bg: rgba(18, 27, 29, 0.95);
    --recterior-header-sticky-border: rgba(255, 255, 255, 0.05);
    --recterior-header-sticky-light-text: #1a1a1a;
    --recterior-header-chip-bg: rgba(18, 27, 29, 0.46);
    --recterior-header-chip-border: rgba(255, 255, 255, 0.22);
    --recterior-header-chip-shadow: 0 10px 28px rgba(0, 0, 0, 0.26);
    --recterior-topbar-blend-mode: difference;
    --recterior-font-body: 'Inter', sans-serif;
    --recterior-font-heading: 'Playfair Display', serif;
    --recterior-menu-font-size: 24px;
    --recterior-menu-font-weight: 600;
    --recterior-menu-letter-spacing: 0px;
    --recterior-menu-text-transform: none;
    --recterior-menu-indicator-display: inline-flex;
    --recterior-menu-color-muted: rgba(255, 255, 255, 0.66);
    --recterior-menu-color: rgba(255, 255, 255, 0.94);
    --recterior-menu-color-active: var(--recterior-accent);
    --recterior-menu-submenu-indent: 1rem;
    --recterior-transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    --recterior-transition-fast: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
    --recterior-transition-slow: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ==========================================================================
   Base / Reset
   ========================================================================== */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--recterior-font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--recterior-text);
    background-color: var(--recterior-bg);
    overflow-x: clip;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--recterior-font-heading);
    color: var(--recterior-heading-color, var(--recterior-white));
    font-weight: 600;
    line-height: 1.2;
}

a {
    color: var(--recterior-accent);
    text-decoration: none;
    transition: var(--recterior-transition);
}

a:hover {
    color: var(--recterior-white);
}

img {
    max-width: 100%;
    height: auto;
}

::selection {
    background-color: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

/* ==========================================================================
   Container Width Override (1400px default)
   ========================================================================== */
.container,
.container-fluid {
    --bs-gutter-x: 2.5rem;
}

@media (min-width: 1200px) {
    .container {
        max-width: 1400px;
    }
}
@media (min-width: 1400px) {
    .container {
        max-width: 1400px;
    }
}

#rct-site-content {
    overflow-x: clip;
}

/* Sticky sidebars/columns: overflow-x:clip on main breaks position:sticky in many browsers */
#rct-site-content.rct-woocommerce,
body.single-post #rct-site-content {
    overflow-x: visible;
}

.recterior-content-shell {
    position: relative;
}

.recterior-content-shell--full {
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
}

/* ==========================================================================
   WordPress Block Alignment
   ========================================================================== */
.alignfull {
    width: 100%;
    max-width: 100%;
}

.alignwide {
    width: 100%;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
}

.recterior-entry-content > .alignfull,
.post-content > .alignfull,
.pf-main-content > .alignfull {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.recterior-entry-content > .alignwide,
.post-content > .alignwide,
.pf-main-content > .alignwide {
    width: min(100%, calc(1600px - var(--bs-gutter-x)));
    max-width: min(100%, calc(1600px - var(--bs-gutter-x)));
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 991.98px) {
    .recterior-entry-content > .alignfull,
    .post-content > .alignfull,
    .pf-main-content > .alignfull {
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
    }
}

.wp-block-recterior-hero-carousel,
.wp-block-recterior-services-section,
.wp-block-recterior-services-flip-cards,
.wp-block-recterior-services-tabs,
.wp-block-recterior-counters,
.wp-block-recterior-cta-section,
.wp-block-recterior-flickity-slideshow,
.wp-block-recterior-numbered-services,
.wp-block-recterior-project-carousel,
.wp-block-recterior-image-showcase,
.wp-block-recterior-multi-image-mask-slider,
.wp-block-recterior-pricing-packages {
    color: var(--recterior-text);
}

.wp-block-recterior-hero-carousel h1,
.wp-block-recterior-hero-carousel h2,
.wp-block-recterior-services-section h1,
.wp-block-recterior-services-section h2,
.wp-block-recterior-services-flip-cards h1,
.wp-block-recterior-services-flip-cards h2,
.wp-block-recterior-services-tabs h1,
.wp-block-recterior-services-tabs h2,
.wp-block-recterior-counters h1,
.wp-block-recterior-counters h2,
.wp-block-recterior-cta-section h1,
.wp-block-recterior-cta-section h2,
.wp-block-recterior-flickity-slideshow h1,
.wp-block-recterior-flickity-slideshow h2,
.wp-block-recterior-numbered-services h1,
.wp-block-recterior-numbered-services h2,
.wp-block-recterior-project-carousel h1,
.wp-block-recterior-project-carousel h2,
.wp-block-recterior-image-showcase h1,
.wp-block-recterior-image-showcase h2,
.wp-block-recterior-multi-image-mask-slider h1,
.wp-block-recterior-multi-image-mask-slider h2 {
    color: var(--recterior-heading-color);
}

.wp-block-recterior-hero-carousel,
.wp-block-recterior-services-section,
.wp-block-recterior-services-flip-cards,
.wp-block-recterior-services-tabs,
.wp-block-recterior-portfolio-grid,
.wp-block-recterior-stats-counters,
.wp-block-recterior-process-steps,
.wp-block-recterior-image-showcase,
.wp-block-recterior-content-carousel,
.wp-block-recterior-team-section,
.wp-block-recterior-testimonials,
.wp-block-recterior-cta-section,
.wp-block-recterior-contact-form,
.wp-block-recterior-numbered-services,
.wp-block-recterior-flickity-slideshow,
.wp-block-recterior-faq-accordion,
.wp-block-recterior-feature-highlight,
.wp-block-recterior-before-after,
.wp-block-recterior-simple-testimonials,
.wp-block-recterior-pricing-packages {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

.wp-block-recterior-services-tabs {
    overflow: visible;
}

/* ==========================================================================
   Gutenberg Core Blocks (Frontend Theme Skin)
   ========================================================================== */
.entry-content > .wp-block,
.post-content > .wp-block,
.pf-main-content > .wp-block {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

.entry-content > .wp-block:first-child,
.post-content > .wp-block:first-child,
.pf-main-content > .wp-block:first-child {
    margin-top: 0;
}

.entry-content > .wp-block:last-child,
.post-content > .wp-block:last-child,
.pf-main-content > .wp-block:last-child {
    margin-bottom: 0;
}

.wp-block-paragraph,
.wp-block-list,
.wp-block-table,
.wp-block-latest-posts,
.wp-block-categories-list,
.wp-block-archives-list {
    color: var(--recterior-text);
}

.wp-block-heading {
    color: var(--recterior-heading-color);
    line-height: 1.2;
}

.wp-block-image figcaption,
.wp-block-gallery figcaption {
    color: var(--recterior-text-muted);
    font-size: 0.9rem;
    margin-top: 0.6rem;
}

.wp-block-quote,
.wp-block-pullquote {
    border-left: 2px solid var(--recterior-accent);
    padding: 1rem 1.25rem;
    margin: 2rem 0;
    background: rgba(255, 255, 255, 0.02);
}

.wp-block-quote p,
.wp-block-pullquote p {
    color: var(--recterior-heading-color);
    font-size: 1.15rem;
    line-height: 1.65;
}

.wp-block-quote cite,
.wp-block-pullquote cite {
    color: var(--recterior-text-muted);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.wp-block-separator {
    border-color: var(--recterior-border);
    opacity: 1;
}

.wp-block-code,
.wp-block-preformatted {
    background: var(--recterior-bg-light);
    border: 1px solid var(--recterior-border);
    color: var(--recterior-text);
    padding: 1rem 1.1rem;
    overflow-x: auto;
}

.wp-block-table table {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--recterior-border);
}

.wp-block-table th,
.wp-block-table td {
    border: 1px solid var(--recterior-border);
    padding: 0.7rem 0.8rem;
}

.wp-block-table th {
    color: var(--recterior-heading-color);
    background: rgba(255, 255, 255, 0.03);
}

.wp-block-button__link {
    background: var(--recterior-accent);
    color: var(--recterior-accent-contrast) !important;
    border: 1px solid var(--recterior-accent);
    font-size: 0.82rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    font-weight: 600;
    padding: 0.85rem 1.4rem;
    transition: var(--recterior-transition-fast);
}

.wp-block-button__link:hover,
.wp-block-button__link:focus {
    background: transparent;
    color: var(--recterior-heading-color) !important;
    border-color: var(--recterior-heading-color);
}

.wp-block-file .wp-block-file__button {
    background: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
    border: 1px solid var(--recterior-accent);
    padding: 0.55rem 1rem;
}

.wp-block-cover,
.wp-block-media-text {
    border: 1px solid var(--recterior-border);
}

.wp-block-group.is-style-default,
.wp-block-group:not(.has-background) {
    border: 1px solid var(--recterior-border);
    padding: 1.25rem;
}

.wp-block-search__input {
    background: transparent;
    border: 1px solid var(--recterior-border);
    color: var(--recterior-heading-color);
}

.wp-block-search__button {
    background: var(--recterior-accent);
    border: 1px solid var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

.wp-block-calendar table {
    border: 1px solid var(--recterior-border);
}

.wp-block-calendar th,
.wp-block-calendar td {
    border: 1px solid var(--recterior-border);
    padding: 0.4rem;
}

.wp-block-latest-comments__comment-meta,
.wp-block-latest-comments__comment-date,
.wp-block-rss__item-publish-date {
    color: var(--recterior-text-muted);
}

[data-bs-theme="light"] .wp-block-quote,
[data-bs-theme="light"] .wp-block-pullquote,
[data-bs-theme="light"] .wp-block-group.is-style-default,
[data-bs-theme="light"] .wp-block-group:not(.has-background),
[data-bs-theme="light"] .wp-block-cover,
[data-bs-theme="light"] .wp-block-media-text,
[data-bs-theme="light"] .wp-block-code,
[data-bs-theme="light"] .wp-block-preformatted {
    background: #fff;
    border-color: rgba(0, 0, 0, 0.12);
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */
.text-accent {
    color: var(--recterior-accent) !important;
}

.bg-accent {
    background-color: var(--recterior-accent) !important;
    color: var(--recterior-accent-contrast) !important;
}

.bg-dark-custom {
    background-color: var(--recterior-bg) !important;
}

.bg-dark-light {
    background-color: var(--recterior-bg-light) !important;
}

.ls-1 {
    letter-spacing: 1px;
}

.ls-2 {
    letter-spacing: 2px;
}

.py-6 {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
}

@media (min-width: 992px) {
    .py-lg-6 {
        padding-top: 5rem !important;
        padding-bottom: 5rem !important;
    }
}

.section-padding {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.section-padding.section-padding--no-top {
    padding-top: 0 !important;
}

.recterior-page-topless .projects-hero,
.recterior-page-topless .about-hero,
.recterior-page-topless .pf-hero-carousel,
.recterior-page-topless .pf-hero-block-wrapper .hero-section,
.recterior-page-topless .pf-hero-block-wrapper .flickity-slideshow {
    padding-top: 0 !important;
}

/* When Start From Top is disabled: 6rem top spacing from page top */
main:not(.recterior-page-topless) > .pf-hero-wrapper:first-child {
    padding-top: 6rem;
}
main:not(.recterior-page-topless) > section:first-child {
    padding-top: 6rem;
}

.recterior-page-title-wrap {
    margin: 0 0 2rem;
}

.recterior-page-title-wrap.has-top-offset {
    padding-top: clamp(72px, 10vw, 130px);
}

.recterior-page-title-wrap.is-left {
    text-align: left;
}

.recterior-page-title-wrap.is-center {
    text-align: center;
}

.recterior-page-title {
    margin: 0;
    color: var(--recterior-heading-color);
}

@media (max-width: 767.98px) {
    .section-padding {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }
    main:not(.recterior-page-topless) > .pf-hero-wrapper:first-child,
    main:not(.recterior-page-topless) > section:first-child {
        padding-top: 3rem;
    }
}

/* ==========================================================================
   Skip Link
   ========================================================================== */
.skip-link.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
    word-wrap: normal !important;
}

.skip-link.screen-reader-text:focus {
    background-color: var(--recterior-accent);
    clip: auto !important;
    display: block;
    font-size: 1em;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
    color: var(--recterior-accent-contrast);
}

/* ==========================================================================
   Navigation / Header
   ========================================================================== */
.recterior-navbar {
    background-color: transparent;
    padding: 1rem 0;
    transition: background-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                padding 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                backdrop-filter 0.4s ease,
                box-shadow 0.4s ease,
                border-color 0.4s ease;
    border-bottom: 1px solid transparent;
    z-index: 9995;
}

.recterior-navbar.scrolled {
    background-color: transparent !important;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    padding: 0.5rem 0;
    border-bottom-color: transparent;
    box-shadow: none;
}

.recterior-navbar .navbar-brand {
    font-size: 1.5rem;
    letter-spacing: 1px;
}

.recterior-navbar .navbar-brand img {
    max-height: 40px;
    width: auto;
}

.recterior-navbar .navbar-brand,
.recterior-navbar .rct-header-actions {
    position: relative;
    z-index: 2;
}

.recterior-navbar.scrolled .navbar-brand,
.recterior-navbar.scrolled .rct-header-actions {
    background: var(--recterior-header-chip-bg);
    border: 1px solid var(--recterior-header-chip-border);
    box-shadow: var(--recterior-header-chip-shadow);
    backdrop-filter: blur(12px) saturate(125%);
    -webkit-backdrop-filter: blur(12px) saturate(125%);
    border-radius: 999px;
}

.recterior-navbar.scrolled .navbar-brand {
    padding: 0.5rem 0.9rem;
}

.recterior-navbar.scrolled .rct-header-actions {
    background: transparent;
    border-color: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-radius: 0;
    padding: 0.38rem 0.7rem;
}

.recterior-navbar .nav-link {
    color: var(--recterior-header-foreground);
    font-size: clamp(0.85rem, 0.65rem + 0.25vw, 1rem);
    font-weight: var(--recterior-menu-font-weight);
    text-transform: var(--recterior-menu-text-transform);
    letter-spacing: var(--recterior-menu-letter-spacing);
    padding: 1.5rem 1rem !important;
    position: relative;
    font-family: var(--recterior-font-body);
    transition: var(--recterior-transition);
}

/* Top bar text/icons blend effect (desktop header) */
.recterior-navbar .nav-link,
.recterior-navbar .link-sup,
.recterior-navbar .rct-menu-trigger__text,
.recterior-navbar .rct-menu-trigger__bar,
.recterior-navbar .rct-lang-dropdown__toggle,
.recterior-navbar .rct-lang-dropdown__toggle i,
.recterior-navbar .rct-drawer-trigger,
.recterior-navbar .rct-drawer-trigger__bar {
    mix-blend-mode: var(--recterior-topbar-blend-mode) !important;
}

.recterior-navbar .rct-header-actions,
.recterior-navbar .rct-header-actions * {
    mix-blend-mode: var(--recterior-topbar-blend-mode) !important;
}

/* Keep dropdown menu content readable when opened. */
.recterior-navbar .rct-header-actions .rct-lang-dropdown__menu,
.recterior-navbar .rct-header-actions .rct-lang-dropdown__menu * {
    mix-blend-mode: normal !important;
}

.recterior-navbar .nav-link:hover,
.recterior-navbar .nav-link.active {
    color: var(--recterior-header-foreground-hover);
}

.recterior-navbar.scrolled .nav-link,
.recterior-navbar:not(.navbar-transparent) .nav-link {
    color: var(--recterior-header-sticky-foreground);
}

.recterior-navbar.scrolled .nav-link:hover,
.recterior-navbar.scrolled .nav-link.active,
.recterior-navbar:not(.navbar-transparent) .nav-link:hover,
.recterior-navbar:not(.navbar-transparent) .nav-link.active {
    color: var(--recterior-header-sticky-foreground-hover);
}

.recterior-navbar .nav-link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 1rem;
    right: 1rem;
    height: 2px;
    background-color: var(--recterior-accent);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.recterior-navbar .nav-link:hover::after,
.recterior-navbar .nav-link.active::after {
    transform: scaleX(1);
}

/* Dropdown fix - remove Bootstrap arrow for custom behavior */
.recterior-navbar .nav-link.dropdown-toggle::after {
    display: none;
}

.link-sup {
    font-size: 0.55em;
    color: var(--recterior-accent);
    margin-left: 0.25em;
    font-weight: 700;
    vertical-align: super;
    font-family: var(--recterior-font-body);
}

.rct-fsm__nav .rct-menu-link--parent,
.rct-mobile-nav .rct-menu-link--parent,
.rct-sd__menu .rct-menu-link--parent {
    display: flex !important;
    align-items: center;
    gap: 0.35em;
}

.rct-menu-indicator {
    display: var(--recterior-menu-indicator-display);
    align-items: center;
    justify-content: center;
    margin-left: auto;
    width: 1em;
    height: 1em;
    position: relative;
    flex: 0 0 1em;
}

.rct-menu-indicator--chevron::after {
    content: '';
    width: 0.42em;
    height: 0.42em;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg);
    transition: transform 0.25s ease;
}

.submenu-open > .rct-menu-link > .rct-menu-indicator--chevron::after {
    transform: rotate(-135deg) translate(-0.04em, -0.04em);
}

.rct-menu-indicator--plus-minus::before,
.rct-menu-indicator--plus-minus::after {
    content: '';
    position: absolute;
    background-color: currentColor;
    transition: transform 0.25s ease, opacity 0.25s ease;
}

.rct-menu-indicator--plus-minus::before {
    width: 0.62em;
    height: 1.5px;
}

.rct-menu-indicator--plus-minus::after {
    width: 1.5px;
    height: 0.62em;
}

.submenu-open > .rct-menu-link > .rct-menu-indicator--plus-minus::after {
    opacity: 0;
    transform: scaleY(0);
}

.social-icon {
    color: var(--recterior-ui-foreground-muted);
    font-size: 0.9rem;
    transition: var(--recterior-transition);
}

.social-icon:hover {
    color: var(--recterior-accent);
}

/* Dropdown Menu */
.dropdown-menu.bg-dark {
    background-color: var(--recterior-header-dropdown-bg) !important;
    border: 1px solid var(--recterior-border);
    border-radius: 0.5rem;
    padding: 0.5rem 0;
    min-width: 220px;
}

.dropdown-item {
    color: var(--recterior-header-dropdown-text);
    padding: 0.5rem 1.25rem;
    font-size: 0.85rem;
    transition: var(--recterior-transition);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--recterior-header-dropdown-hover-bg);
    color: var(--recterior-header-dropdown-hover-text);
}

/* (Mobile nav toggle replaced by custom .rct-menu-trigger) */

/* ==========================================================================
   Hero Section
   ========================================================================== */
.hero-section {
    position: relative;
    min-height: var(--rct-hero-height, 100vh);
    min-height: var(--rct-hero-height, 100svh);
    overflow: hidden;
    display: flex;
    align-items: center;
}

.hero-carousel .carousel-item {
    min-height: var(--rct-hero-height, 100vh);
    min-height: var(--rct-hero-height, 100svh);
}

.hero-slide {
    position: relative;
    min-height: var(--rct-hero-height, 100vh);
    min-height: var(--rct-hero-height, 100svh);
    display: flex;
    align-items: flex-end;
    padding: 8rem 0 6rem;
    overflow: hidden;
}

.hero-section--full-width .hero-slide .hero-content {
    width: 100%;
    max-width: none;
    padding-left: clamp(1rem, 4vw, 4rem);
    padding-right: clamp(1rem, 4vw, 4rem);
}

.hero-section--full-width.hero-style-offset-overlap {
    --rct-hero-media-left-gap: clamp(4rem, 9vw, 12rem);
    --rct-hero-content-width: min(80vw, 70rem);
    --rct-hero-content-shift: -18%;
}

.hero-slide__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 0;
    will-change: transform;
    transform-origin: center center;
}

.hero-slide--center {
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 8rem 0;
}

.hero-slide::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(18, 27, 29, 0.9) 0%,
        rgba(18, 27, 29, 0.5) 40%,
        rgba(18, 27, 29, 0.3) 100%
    );
    z-index: 1;
}

.hero-slide .hero-content {
    position: relative;
    z-index: 2;
}

.hero-slide__video-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    pointer-events: none;
    will-change: transform;
    transform-origin: center center;
}

.hero-slide__youtube-bg {
    position: absolute;
    inset: -60px;
    width: calc(100% + 120px);
    height: calc(100% + 120px);
    z-index: 0;
    pointer-events: none;
    border: none;
    will-change: transform;
    transform-origin: center center;
}

.hero-slide__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.hero-subtitle {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--recterior-accent);
    margin-bottom: 1rem;
    font-family: var(--recterior-font-body);
}

.hero-title {
    font-size: var(--rct-hero-title-size, clamp(2rem, 4vw, 3rem));
    font-weight: 600;
    color: var(--recterior-white);
    line-height: 1.1;
    margin-bottom: 2rem;
}

.hero-carousel .carousel-indicators {
    bottom: 2rem;
    justify-content: flex-start;
    margin-left: 2rem;
}

.hero-carousel .carousel-indicators [data-bs-target] {
    width: 40px;
    height: 3px;
    background-color: rgba(255, 255, 255, 0.3);
    border: 0;
    transition: var(--recterior-transition);
}

.hero-carousel .carousel-indicators [data-bs-target].active {
    background-color: var(--recterior-accent);
    width: 60px;
}

.hero-carousel .carousel-control-prev,
.hero-carousel .carousel-control-next {
    width: 4rem;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 5;
}

.hero-carousel:hover .carousel-control-prev,
.hero-carousel:hover .carousel-control-next {
    opacity: 0.7;
}

.hero-carousel .carousel-control-prev:hover,
.hero-carousel .carousel-control-next:hover {
    opacity: 1;
}

.hero-carousel .carousel-control-prev-icon,
.hero-carousel .carousel-control-next-icon {
    width: 2rem;
    height: 2rem;
}

.hero-carousel {
    cursor: grab;
}

.hero-carousel--dragging {
    cursor: grabbing;
}

.hero-carousel--dragging * {
    pointer-events: none;
}

/* Hero style 2: media shifted right, text overlapping from left */
.hero-style-offset-overlap {
    --rct-hero-media-left-gap: clamp(8rem, 12vw, 16rem);
    --rct-hero-content-width: min(68vw, 60rem);
    --rct-hero-content-shift: -30%;
}

.hero-style-offset-overlap .hero-slide__bg,
.hero-style-offset-overlap .hero-slide__video-bg,
.hero-style-offset-overlap .hero-slide__youtube-bg {
    left: var(--rct-hero-media-left-gap);
    width: calc(100% - var(--rct-hero-media-left-gap));
}

.hero-style-offset-overlap .hero-slide .hero-content {
    position: relative;
    z-index: 2;
    width: var(--rct-hero-content-width);
    margin-left: var(--rct-hero-media-left-gap);
    transform: translateX(var(--rct-hero-content-shift));
    padding-right: 2rem;
}

/* Style 2 arrows: bottom-left rectangular white buttons */
.hero-carousel--nav-rect-left .carousel-control-prev,
.hero-carousel--nav-rect-left .carousel-control-next {
    top: auto;
    bottom: 2rem;
    width: 54px;
    height: 44px;
    opacity: 1;
    background: #ffffff;
    border: 1px solid rgba(17, 26, 29, 0.15);
    color: #111a1d;
    z-index: 6;
}

.hero-carousel--nav-rect-left .carousel-control-prev {
    left: 2rem;
}

.hero-carousel--nav-rect-left .carousel-control-next {
    left: calc(2rem + 62px);
    right: auto;
}

.hero-carousel--nav-rect-left .carousel-control-prev-icon,
.hero-carousel--nav-rect-left .carousel-control-next-icon {
    width: 1.1rem;
    height: 1.1rem;
    filter: invert(1);
}

.hero-carousel--nav-rect-left .carousel-control-prev:hover,
.hero-carousel--nav-rect-left .carousel-control-next:hover {
    background: var(--recterior-accent);
    border-color: var(--recterior-accent);
}

.hero-carousel--nav-rect-left .carousel-control-prev:hover .carousel-control-prev-icon,
.hero-carousel--nav-rect-left .carousel-control-next:hover .carousel-control-next-icon {
    filter: invert(0);
}

.hero-carousel--nav-rect-left .carousel-control-prev:focus-visible,
.hero-carousel--nav-rect-left .carousel-control-next:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 2px;
}

@media (min-width: 1600px) {
    .hero-style-offset-overlap {
        --rct-hero-media-left-gap: 18rem;
        --rct-hero-content-width: 62rem;
        --rct-hero-content-shift: -30%;
    }
}

@media (max-width: 1399.98px) {
    .hero-style-offset-overlap {
        --rct-hero-media-left-gap: clamp(6rem, 10vw, 10rem);
        --rct-hero-content-width: min(72vw, 52rem);
        --rct-hero-content-shift: -24%;
    }
}

@media (max-width: 991.98px) {
    .hero-style-offset-overlap .hero-slide__bg,
    .hero-style-offset-overlap .hero-slide__video-bg,
    .hero-style-offset-overlap .hero-slide__youtube-bg {
        left: clamp(1rem, 3.5vw, 2rem);
        width: calc(100% - clamp(1rem, 3.5vw, 2rem));
    }

    .hero-style-offset-overlap .hero-slide .hero-content {
        width: calc(100% - clamp(2rem, 5vw, 3rem));
        margin-left: clamp(1rem, 3.5vw, 2rem);
        transform: translateX(-8%);
        padding-right: 0;
    }

    .hero-section--full-width.hero-style-offset-overlap .hero-slide .hero-content {
        transform: none;
    }

    .hero-carousel--nav-rect-left .carousel-control-prev {
        left: 1rem;
        bottom: 1rem;
    }

    .hero-carousel--nav-rect-left .carousel-control-next {
        left: calc(1rem + 58px);
        bottom: 1rem;
    }
}

@media (max-width: 1399.98px) {
    .recterior-navbar.scrolled .navbar-brand {
        padding: 0.42rem 0.78rem;
    }

    .recterior-navbar.scrolled .rct-header-actions {
        padding: 0.3rem 0.58rem;
        gap: 0.6rem !important;
    }

    .recterior-navbar.scrolled .rct-menu-trigger,
    .recterior-navbar.scrolled .rct-drawer-trigger {
        padding: 0.38rem;
    }
}

@media (max-width: 767px) {
    .hero-style-offset-overlap .hero-slide__bg,
    .hero-style-offset-overlap .hero-slide__video-bg,
    .hero-style-offset-overlap .hero-slide__youtube-bg {
        left: 0;
        width: 100%;
    }

    .hero-style-offset-overlap .hero-slide .hero-content {
        width: calc(100% - 2rem);
        margin-left: 1rem;
        transform: none;
    }

    .hero-section--full-width .hero-slide .hero-content {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

/* ==========================================================================
   Buttons
   ========================================================================== */

/* --- Solid accent button (primary CTA) --- */
.btn-accent {
    background-color: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
    border: 2px solid var(--recterior-accent);
    padding: 0.75rem 2rem;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    border-radius: 0;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: background-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.btn-accent:hover,
.btn-accent:focus {
    background-color: transparent;
    color: var(--recterior-white);
    border-color: var(--recterior-accent);
}

.btn-accent i {
    transition: transform 0.3s ease;
}

.btn-accent:hover i {
    transform: translateX(4px);
}

/* --- Outlined accent button --- */
.btn-outline-accent {
    background-color: transparent;
    color: var(--recterior-white);
    border: 2px solid var(--recterior-accent);
    padding: 0.75rem 2rem;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    border-radius: 0;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: background-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.btn-outline-accent:hover,
.btn-outline-accent:focus {
    background-color: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

/* --- Underlined text button (secondary CTA) --- */
.btn-underlined {
    background: none;
    border: none;
    color: var(--recterior-white);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding: 0;
    padding-bottom: 4px;
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
    transition: color 0.3s ease;
}

.btn-underlined::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: var(--recterior-accent);
    transform: scaleX(0.3);
    transform-origin: left;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.btn-underlined:hover::after,
.btn-underlined:focus::after {
    transform: scaleX(1);
}

.btn-underlined:hover,
.btn-underlined:focus {
    color: var(--recterior-white);
    text-decoration: none;
}

.btn-underlined i {
    transition: transform 0.3s ease;
    font-size: 0.7em;
}

.btn-underlined:hover i {
    transform: translateX(5px);
}

/* --- Ensure anchor buttons inherit correct colors --- */
a.btn-accent,
a.btn-accent:visited,
a.btn-outline-accent,
a.btn-outline-accent:visited,
a.btn-underlined,
a.btn-underlined:visited {
    color: var(--recterior-white);
    text-decoration: none;
}

a.btn-accent:hover {
    color: var(--recterior-white);
    text-decoration: none;
}

a.btn-outline-accent:hover {
    color: var(--recterior-white);
    text-decoration: none;
}

a.btn-underlined:hover {
    color: var(--recterior-white);
    text-decoration: none;
}

/* --- Button size overrides (complement Bootstrap btn-lg / btn-sm) --- */
.btn-accent.btn-lg,
.btn-outline-accent.btn-lg {
    padding: 1rem 2.5rem;
    font-size: 0.85rem;
}

.btn-accent.btn-sm,
.btn-outline-accent.btn-sm {
    padding: 0.5rem 1.25rem;
    font-size: 0.7rem;
    letter-spacing: 1px;
}

/* ==========================================================================
   Trusted Experience / About Section
   ========================================================================== */
.trusted-section {
    position: relative;
}

.experience-counter {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.experience-counter .counter-value {
    font-size: 5rem;
    font-weight: 700;
    color: var(--recterior-accent);
    line-height: 1;
    font-family: var(--recterior-font-heading);
}

.experience-counter .counter-suffix {
    font-size: 2rem;
    color: var(--recterior-accent);
}

/* ==========================================================================
   Services Section
   ========================================================================== */
.services-list .service-item {
    padding: 1rem 0;
    border-bottom: 1px solid var(--recterior-border);
    transition: var(--recterior-transition);
    cursor: default;
}

.services-list .service-item .service-icon {
    color: var(--recterior-accent);
    font-size: 1.25rem;
    width: 2rem;
}

.services-list .service-item .service-name {
    color: var(--recterior-white);
    font-size: 1rem;
    font-weight: 500;
}

/* ==========================================================================
   Card Columns (formerly Process Steps)
   ========================================================================== */
.card-columns-section {
    position: relative;
}

.card-columns-section .row {
    align-items: stretch;
}

.card-columns-section.card-columns--page-width > .container {
    padding-left: 0;
    padding-right: 0;
}

.card-columns__card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--recterior-border, #2a3638);
    transition: var(--recterior-transition);
    height: 100%;
    padding: 2rem;
}

.card-columns__card:hover {
    border-color: var(--recterior-accent);
    transform: translateY(-5px);
}

.card-columns__card-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.card-columns__card-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.card-columns--align-left .card-columns__card-inner {
    align-items: flex-start;
    text-align: left;
}

.card-columns--align-center .card-columns__card-inner {
    align-items: center;
    text-align: center;
}

.card-columns--align-right .card-columns__card-inner {
    align-items: flex-end;
    text-align: right;
}

.card-columns__number {
    font-size: var(--rct-card-number-size, 3rem);
    font-weight: var(--rct-card-number-weight, 700);
    color: var(--rct-card-number-color, rgba(172, 140, 102, 0.2));
    line-height: 1;
    margin-bottom: 1rem;
    font-family: var(--recterior-font-heading);
}

.card-columns--number-align-left .card-columns__number {
    align-self: flex-start;
    text-align: left;
}

.card-columns--number-align-center .card-columns__number {
    align-self: center;
    text-align: center;
}

.card-columns--number-align-right .card-columns__number {
    align-self: flex-end;
    text-align: right;
}

.card-columns--number-absolute .card-columns__card--has-number .card-columns__card-inner {
    position: relative;
    padding-top: calc(var(--rct-card-number-size, 3rem) + 0.85rem);
}

.card-columns--number-absolute .card-columns__number {
    position: absolute;
    top: 0;
    margin-bottom: 0;
    z-index: 2;
    pointer-events: none;
}

.card-columns--number-absolute.card-columns--number-align-left .card-columns__number {
    left: 0;
    right: auto;
    transform: none;
}

.card-columns--number-absolute.card-columns--number-align-center .card-columns__number {
    left: 50%;
    right: auto;
    transform: translateX(-50%);
}

.card-columns--number-absolute.card-columns--number-align-right .card-columns__number {
    right: 0;
    left: auto;
    transform: none;
}

.card-columns__number--outlined {
    -webkit-text-stroke: var(--rct-card-number-outline-width, 2px) var(--rct-card-number-outline-color, var(--rct-card-number-color, rgba(172, 140, 102, 0.35)));
    color: transparent;
    text-shadow: 0 0 0 var(--rct-card-number-outline-color, var(--rct-card-number-color, rgba(172, 140, 102, 0.35)));
}

.card-columns__icon {
    margin-bottom: 1rem;
}

.card-columns__icon--fa {
    font-size: 2rem;
    color: var(--rct-card-icon-color, var(--recterior-accent));
}

.card-columns__icon--img {
    max-width: 3rem;
    height: auto;
}

.card-columns__title {
    font-size: var(--rct-card-heading-size, 1.35rem);
    color: var(--rct-card-heading-color, var(--recterior-heading-color));
    margin-top: .35rem;
    margin-bottom: 0.75rem;
}

.card-columns__card--no-number .card-columns__title,
.card-columns--number-absolute .card-columns__title {
    margin-top: 0;
}

.card-columns__description {
    font-size: var(--rct-card-text-size, 0.9rem);
    color: var(--rct-card-text-color, var(--recterior-text-muted));
    margin-bottom: 1rem;
    flex: 1;
}

.card-columns__btn {
    background-color: var(--rct-card-button-bg, var(--recterior-accent)) !important;
    color: var(--rct-card-button-text, #fff) !important;
    align-self: flex-start;
    padding: 0.5rem 0.9rem;
}

.card-columns--align-center .card-columns__btn {
    align-self: center;
}

.card-columns--align-right .card-columns__btn {
    align-self: flex-end;
}

.card-columns--horizontal .card-columns__card-inner {
    flex-direction: row;
    align-items: flex-start;
    gap: 1.25rem;
}

.card-columns--horizontal .card-columns__number,
.card-columns--horizontal .card-columns__icon {
    margin-bottom: 0;
    flex-shrink: 0;
}

.card-columns--horizontal .card-columns__number {
    font-size: var(--rct-card-number-size, 2rem);
}

.card-columns--horizontal .card-columns__title,
.card-columns--horizontal .card-columns__description,
.card-columns--horizontal .card-columns__btn {
    flex: 1 1 auto;
}

.card-columns--horizontal.card-columns--align-center .card-columns__card-inner {
    align-items: center;
}

.card-columns--horizontal.card-columns--align-right .card-columns__card-inner {
    flex-direction: row-reverse;
}

/* Legacy process-step (template-parts/content-process.php) */
.process-step {
    position: relative;
    padding: 2rem;
    border: 1px solid var(--recterior-border);
    border-radius: 0.5rem;
    transition: var(--recterior-transition);
    height: 100%;
}

.process-step:hover {
    border-color: var(--recterior-accent);
    transform: translateY(-5px);
}

.process-step .step-number {
    font-size: 3rem;
    font-weight: 700;
    color: rgba(172, 140, 102, 0.2);
    line-height: 1;
    margin-bottom: 1.5rem;
    font-family: var(--recterior-font-heading);
}

.process-step h3 {
    font-size: 1.35rem;
    margin-bottom: 1rem;
}

.process-step p {
    color: var(--recterior-text-muted);
    font-size: 0.9rem;
    margin-bottom: 0;
}

/* ==========================================================================
   Image Showcase / Slider
   ========================================================================== */
.showcase-section {
    position: relative;
}

.showcase-grid {
    display: grid;
    grid-template-columns: repeat(var(--rct-showcase-cols, 2), minmax(0, 1fr));
    gap: var(--rct-showcase-gap, 16px);
}

.showcase-item-wrap {
    display: block;
    color: inherit;
    text-decoration: none;
}

.showcase-item-wrap:focus-visible {
    outline: 2px solid var(--recterior-accent, #AC8C66);
    outline-offset: 2px;
}

.showcase-item {
    position: relative;
    overflow: hidden;
    min-height: var(--rct-showcase-min-h, 420px);
    border-radius: var(--rct-showcase-radius, 0);
    border: var(--rct-showcase-border-w, 0) solid var(--rct-showcase-border-color, transparent);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform 0.32s cubic-bezier(0.16, 1, 0.3, 1), filter 0.28s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

.showcase-section--fixed-ratio .showcase-item {
    min-height: 0;
    aspect-ratio: var(--rct-showcase-aspect, 16/9);
}

.showcase-item.showcase-shadow-sm {
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.2);
}

.showcase-item.showcase-shadow-md {
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
}

.showcase-item.showcase-shadow-lg {
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
}

.showcase-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.42s cubic-bezier(0.16, 1, 0.3, 1);
}

.showcase-item:hover img {
    transform: scale(1.05);
}

.showcase-item .showcase-overlay {
    position: absolute;
    inset: 0;
    background: var(--rct-showcase-overlay-color, #121B1D);
    display: flex;
    flex-direction: column;
    justify-content: var(--rct-showcase-content-justify, flex-end);
    padding: 2rem;
    opacity: var(--rct-showcase-overlay-opacity, 0.5);
    transition: opacity 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

.showcase-item.hover-reveal .showcase-overlay {
    opacity: 0;
}

.showcase-item.hover-reveal:hover .showcase-overlay {
    opacity: 1;
}

.showcase-item.hover-fade:hover {
    filter: brightness(0.9);
}

.showcase-item.hover-zoom:hover {
    transform: scale(1.02);
}

.showcase-content {
    text-align: var(--rct-showcase-content-align, left);
}

.showcase-item .showcase-title {
    font-size: var(--rct-showcase-title-size, 1.5rem);
    font-weight: var(--rct-showcase-title-weight, 600);
    text-transform: var(--rct-showcase-title-transform, none);
    color: var(--recterior-white);
    margin-bottom: 0.5rem;
    transform: translateY(20px);
    transition: transform 0.32s cubic-bezier(0.16, 1, 0.3, 1);
}

.showcase-item:hover .showcase-title {
    transform: translateY(0);
}

.showcase-item .showcase-desc {
    color: var(--recterior-text-muted);
    font-size: var(--rct-showcase-desc-size, 0.9rem);
    transform: translateY(20px);
    transition: transform 0.32s cubic-bezier(0.16, 1, 0.3, 1) 0.06s;
}

.showcase-item:hover .showcase-desc {
    transform: translateY(0);
}

@media (max-width: 991.98px) {
    .showcase-grid {
        grid-template-columns: repeat(var(--rct-showcase-cols-tablet, 2), minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .showcase-grid {
        grid-template-columns: repeat(var(--rct-showcase-cols-mobile, 1), minmax(0, 1fr));
    }

    .showcase-item .showcase-overlay {
        padding: 1.3rem;
    }
}

/* ==========================================================================
   Counters Section
   ========================================================================== */
.counters-section {
    background-color: var(--recterior-bg-light);
}

.counter-box {
    text-align: center;
    padding: 2rem 1rem;
}

.counter-box .counter-value {
    font-size: 3rem;
    font-weight: 700;
    color: var(--recterior-white);
    line-height: 1;
    margin-bottom: 0.75rem;
    font-family: var(--recterior-font-heading);
}

.counter-box .counter-label {
    font-size: 0.85rem;
    color: var(--recterior-text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ==========================================================================
   Portfolio Grid
   ========================================================================== */
.portfolio-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2.5rem;
}

.portfolio-filters .filter-btn {
    background: none;
    border: none;
    color: var(--recterior-text-muted);
    font-size: 0.85rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 0.5rem 1.25rem;
    cursor: pointer;
    transition: var(--recterior-transition);
    border-radius: 0;
    border-bottom: 2px solid transparent;
}

.portfolio-filters .filter-btn:hover,
.portfolio-filters .filter-btn.active {
    color: var(--recterior-white);
    border-bottom-color: var(--recterior-accent);
}

.portfolio-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

@media (max-width: 991.98px) {
    .portfolio-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 575.98px) {
    .portfolio-grid {
        grid-template-columns: 1fr;
    }
}

.portfolio-item {
    position: relative;
    overflow: hidden;
    border-radius: 0.5rem;
    aspect-ratio: 3 / 4;
}

.portfolio-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.portfolio-item:hover img {
    transform: scale(1.08);
}

.portfolio-item .portfolio-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(18, 27, 29, 0.9) 0%, transparent 60%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1.5rem;
    transition: var(--recterior-transition);
}

.portfolio-item .portfolio-category {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--recterior-accent);
    margin-bottom: 0.5rem;
}

.portfolio-item .portfolio-title {
    font-size: 1.25rem;
    color: var(--recterior-white);
    margin: 0;
    font-family: var(--recterior-font-heading);
}

.portfolio-item .portfolio-link {
    position: absolute;
    inset: 0;
    z-index: 2;
}

/* ==========================================================================
   Services Tabs
   ========================================================================== */
.services-tabs .nav-tabs {
    border-bottom: 1px solid var(--recterior-border);
    gap: 0.2rem;
}

.services-tabs.tabs-align-left .nav-tabs {
    justify-content: flex-start;
}

.services-tabs.tabs-align-center .nav-tabs {
    justify-content: center;
}

.services-tabs.tabs-align-right .nav-tabs {
    justify-content: flex-end;
}

.services-tabs__intro {
    width: 100%;
    max-width: none;
}

.services-tabs__intro-title {
    margin: 0 0 0.45rem;
    color: var(--recterior-heading-color);
    font-size: clamp(1.5rem, 2.5vw, 2.2rem);
    line-height: 1.2;
    display: block;
    max-width: min(100%, 820px);
}

.services-tabs__intro-description {
    margin: 0;
    color: var(--recterior-text-muted);
    font-size: 1rem;
    display: block;
    max-width: min(100%, 820px);
}

.services-tabs__intro-title--center,
.services-tabs__intro-description--center {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.services-tabs__intro-title--left,
.services-tabs__intro-description--left {
    margin-left: 0;
    margin-right: auto;
    text-align: left;
}

.services-tabs__intro-title--right,
.services-tabs__intro-description--right {
    margin-left: auto;
    margin-right: 0;
    text-align: right;
}

.services-tabs .nav-tabs .nav-link {
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--recterior-text-muted);
    font-family: var(--recterior-font-heading);
    font-size: 1.1rem;
    font-weight: 600;
    padding: 1rem 1.5rem;
    background: none;
    border-radius: 0;
    transition: var(--recterior-transition);
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.services-tabs .nav-tabs .nav-link.services-tabs__nav-link {
    color: var(--recterior-text-muted);
}

.services-tabs .nav-tabs .nav-link:hover {
    color: var(--recterior-white);
    border-color: transparent;
}

.services-tabs .nav-tabs .nav-link.active {
    color: var(--recterior-white);
    background: none;
    border-bottom-color: var(--recterior-accent);
}

.services-tabs .nav-tabs .nav-link.services-tabs__nav-link.active {
    color: var(--recterior-heading-color);
}

.services-tabs .tab-content {
    padding-top: 2rem;
}

.services-tabs__tabs-shell {
    display: block;
}

.services-tabs .tab-pane.fade {
    transition: opacity var(--rct-st-transition, 350ms) ease;
}

.services-tabs .tab-pane.tab-slide {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity var(--rct-st-transition, 350ms) ease, transform var(--rct-st-transition, 350ms) ease;
}

.services-tabs .tab-pane.tab-slide.show.active {
    opacity: 1;
    transform: translateY(0);
}

.services-tabs .tab-pane h4 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.services-tabs .tab-pane p {
    color: var(--recterior-text-muted);
    max-width: 600px;
}

.services-tabs__pane-heading {
    color: var(--recterior-heading-color);
}

.services-tabs__pane-description {
    color: var(--recterior-text-muted);
    line-height: var(--rct-st-pane-desc-line-height, 1.2);
    max-width: 600px;
}

.services-tabs__pane-description--left {
    text-align: left;
    margin-left: 0;
    margin-right: auto;
}

.services-tabs__pane-description--center {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.services-tabs__pane-description--right {
    text-align: right;
    margin-left: auto;
    margin-right: 0;
}

.services-tabs__pane-description p {
    margin: 0 0 1rem;
}

.services-tabs__pane-description p:last-child {
    margin-bottom: 0;
}

.services-tabs__pane-cta {
    color: var(--recterior-heading-color);
}

.services-tabs__tab-icon {
    color: var(--recterior-accent);
}

.services-tabs__tab-badge {
    display: inline-block;
    padding: 0.15rem 0.4rem;
    border: 1px solid var(--recterior-border);
    border-radius: 999px;
    font-size: 0.68rem;
    line-height: 1;
    opacity: 0.85;
}

.services-tabs__pane--has-image .services-tabs__content-col {
    text-align: left;
}

.services-tabs__pane--has-image {
    align-items: flex-start !important;
}

.services-tabs__pane--no-image .services-tabs__content-col {
    text-align: center;
    max-width: min(100%, var(--rct-st-content-max, 760px));
    margin-left: auto;
    margin-right: auto;
}

.services-tabs.tabs-content-auto .services-tabs__pane--no-image .services-tabs__content-col {
    max-width: 100%;
}

.services-tabs__media-wrap {
    position: relative;
    overflow: hidden;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--recterior-border);
}

.services-tabs__media-img {
    display: block;
    width: 100%;
    aspect-ratio: var(--rct-st-image-ratio, 4/3);
    min-height: var(--rct-st-image-min-height, 260px);
    height: auto;
    object-fit: cover;
}

.services-tabs__media-col {
    position: sticky;
    top: clamp(84px, 8vw, 120px);
    align-self: flex-start;
}

.services-tabs .tab-pane.tab-slide.show.active {
    transform: none;
}

.services-tabs__content-col .btn-underlined {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.services-tabs.tabs-vertical .services-tabs__tabs-shell {
    display: grid;
    grid-template-columns: minmax(180px, var(--rct-st-vertical-nav-width, 260px)) minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
}

.services-tabs.tabs-vertical .nav-tabs {
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start !important;
    border-bottom: 0;
    border-right: 0;
    padding-right: 1rem;
    margin-bottom: 0 !important;
}

.services-tabs.tabs-vertical .tab-content {
    padding-top: 0;
}

.services-tabs.tabs-vertical .nav-tabs .nav-link {
    text-align: left;
    border-bottom: 2px solid transparent;
    border-right: 0;
    padding: 0.9rem 0.25rem;
}

.services-tabs.tabs-vertical.tabs-align-center .nav-tabs .nav-link {
    text-align: center;
}

.services-tabs.tabs-vertical.tabs-align-right .nav-tabs .nav-link {
    text-align: right;
}

.services-tabs.tabs-vertical .nav-tabs .nav-link.active {
    border-right-color: transparent;
    border-bottom-color: var(--recterior-accent);
}

/* ==========================================================================
   Interior Design Carousel
   ========================================================================== */
.interior-carousel .carousel-item {
    padding: 3rem 0;
}

.interior-carousel .carousel-label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--recterior-accent);
    margin-bottom: 1rem;
}

.interior-carousel .carousel-heading {
    font-size: 1.25rem;
    color: var(--recterior-white);
    margin-bottom: 1.5rem;
    line-height: 1.6;
}

/* ==========================================================================
   Team Section
   ========================================================================== */
.team-member {
    position: relative;
    overflow: hidden;
    border-radius: 0.5rem;
    text-align: center;
}

.team-member .team-photo {
    position: relative;
    overflow: hidden;
    margin-bottom: 1.25rem;
    border-radius: 0.5rem;
    aspect-ratio: 4 / 5;
}

.team-member .team-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    filter: grayscale(30%);
}

.team-member:hover .team-photo img {
    transform: scale(1.05);
    filter: grayscale(0%);
}

.team-member .team-name {
    font-size: 1.1rem;
    margin-bottom: 0.25rem;
}

.team-member .team-role {
    font-size: 0.8rem;
    color: var(--recterior-text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ==========================================================================
   Testimonials
   ========================================================================== */
.testimonials-section {
    position: relative;
}

.testimonials-section.testimonials-section--page-width > .container {
    padding-left: 0;
    padding-right: 0;
}

.testimonial-card {
    padding: 2rem;
    border: 1px solid var(--rct-testimonial-card-border-color, var(--recterior-border));
    border-radius: 0.5rem;
    height: 100%;
    transition: var(--recterior-transition);
    text-align: var(--rct-testimonial-content-align, left);
}

.testimonial-card:hover {
    border-color: var(--recterior-accent);
}

.testimonial-card .testimonial-text {
    font-size: var(--rct-testimonial-quote-size, 1rem);
    font-weight: var(--rct-testimonial-quote-weight, 400);
    line-height: var(--rct-testimonial-quote-line-height, 1.8);
    color: var(--rct-testimonial-quote-color, var(--recterior-text));
    margin-bottom: 1.5rem;
    font-style: italic;
    position: relative;
    padding-left: calc(var(--rct-testimonial-quote-mark-size, 1.75rem) + var(--rct-testimonial-quote-mark-gap, 6px));
    padding-right: calc(var(--rct-testimonial-quote-mark-size, 1.75rem) + var(--rct-testimonial-quote-mark-gap, 6px));
}

.testimonial-card .testimonial-quote-mark {
    font-size: var(--rct-testimonial-quote-mark-size, 1.75rem);
    line-height: 1;
    position: absolute;
    top: 0;
    display: block;
    color: var(--rct-testimonial-quote-icon-color, var(--rct-testimonial-quote-color, var(--recterior-text)));
    pointer-events: none;
    opacity: 0.92;
}

.testimonial-card .testimonial-quote-mark--open {
    left: 0;
}

.testimonial-card .testimonial-quote-mark--close {
    right: 0;
    top: auto;
    bottom: 0;
}

.testimonial-card .testimonial-quote-content {
    display: block;
}

.testimonial-card .testimonial-title {
    color: var(--recterior-heading-color);
    text-align: var(--rct-testimonial-title-align, var(--rct-testimonial-content-align, left));
    font-size: var(--rct-testimonial-title-size, 1.125rem);
    font-weight: var(--rct-testimonial-title-weight, 600);
}

.testimonial-card .testimonial-title.testimonial-title--bottom {
    margin-top: 0.5rem;
}

.testimonial-card .testimonial-author {
    display: flex;
    align-items: center;
    justify-content: var(--rct-testimonial-author-justify, flex-start);
    text-align: var(--rct-testimonial-author-align, left);
    gap: 1rem;
}

.testimonial-card .testimonial-author .author-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
}

.testimonial-card .testimonial-author .author-name {
    font-size: var(--rct-testimonial-author-size, 1rem);
    color: var(--rct-testimonial-author-color, var(--recterior-heading-color));
    margin: 0;
}

.testimonial-card .testimonial-author .author-role {
    font-size: var(--rct-testimonial-role-size, 0.75rem);
    color: var(--recterior-text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Testimonials Carousel */
.testimonials-carousel.testimonials-carousel--cols {
    overflow: hidden;
    position: relative;
}

.testimonials-carousel.testimonials-carousel--cols .rct-testimonials-track {
    display: flex;
    align-items: stretch;
    transition: transform var(--rct-testimonial-slide-duration, 560ms) cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
}

.testimonials-carousel .rct-testimonials-slide {
    padding: 1rem;
    flex: 0 0 calc(100% / var(--rct-testimonial-cols-current, var(--rct-testimonial-cols-desktop, 1)));
    width: auto;
    margin-right: 0;
    float: none;
    display: block !important;
    transition: opacity var(--rct-testimonial-slide-duration, 560ms) ease;
    transform: translateZ(0);
    backface-visibility: hidden;
    will-change: opacity;
}

.testimonials-carousel .rct-testimonials-slide .testimonial-card {
    height: 100%;
}

.testimonials-carousel .carousel-control-prev,
.testimonials-carousel .carousel-control-next {
    width: 3rem;
    height: 3rem;
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--recterior-bg-light);
    border: 1px solid var(--recterior-border);
    border-radius: 50%;
    opacity: 0.7;
    transition: var(--recterior-transition);
}

.testimonials-carousel .carousel-control-prev:hover,
.testimonials-carousel .carousel-control-next:hover {
    opacity: 1;
    border-color: var(--recterior-accent);
}

.testimonials-carousel .carousel-control-prev {
    left: -1.5rem;
}

.testimonials-carousel .carousel-control-next {
    right: -1.5rem;
}

.testimonials-section--title-top .testimonial-card .testimonial-title {
    order: 2;
}

.testimonials-section--title-bottom .testimonial-card .testimonial-title {
    order: 4;
}

.testimonials-section--author-above .testimonial-card .testimonial-author {
    margin-bottom: 1rem;
}

.testimonials-section--author-below .testimonial-card .testimonial-author {
    margin-top: 0.5rem;
}

.testimonials-section--arrows-author .testimonial-nav {
    display: none;
}

.testimonials-section--arrows-author .testimonial-author--with-nav {
    gap: 0.75rem;
}

.testimonials-section--arrows-author .testimonial-author--with-nav .carousel-control-prev,
.testimonials-section--arrows-author .testimonial-author--with-nav .carousel-control-next {
    position: relative;
    top: auto;
    transform: none;
    left: auto;
    right: auto;
    flex: 0 0 auto;
    width: 2.5rem;
    height: 2.5rem;
}

.testimonials-section--arrows-sides .testimonials-carousel .testimonial-nav {
    position: absolute;
    inset: 0;
    z-index: 6;
}

.testimonials-section--arrows-sides .testimonials-carousel .testimonial-nav .carousel-control-prev,
.testimonials-section--arrows-sides .testimonials-carousel .testimonial-nav .carousel-control-next {
    position: absolute !important;
    top: 50%;
    transform: translateY(-50%);
    z-index: 7;
}

.testimonials-section--arrows-sides .testimonials-carousel .testimonial-nav .carousel-control-prev {
    left: 0.5rem;
}

.testimonials-section--arrows-sides .testimonials-carousel .testimonial-nav .carousel-control-next {
    right: 0.5rem;
}

.testimonials-section--arrows-sides .testimonials-carousel.testimonials-carousel--cols {
    overflow: visible;
}

.testimonials-carousel.testimonials-carousel--cols.is-sliding .rct-testimonials-slide {
    pointer-events: none;
}

.testimonials-carousel.testimonials-carousel--cols.is-sliding .rct-testimonials-slide[aria-hidden="true"] {
    opacity: 0.96;
}

@media (max-width: 991.98px) {
    .testimonials-carousel.testimonials-carousel--cols {
        --rct-testimonial-cols-current: var(--rct-testimonial-cols-tablet, 1);
    }
}

@media (max-width: 767.98px) {
    .testimonials-carousel.testimonials-carousel--cols {
        --rct-testimonial-cols-current: var(--rct-testimonial-cols-mobile, 1);
    }
}

/* ==========================================================================
   CTA Section
   ========================================================================== */
.cta-section {
    background-color: var(--recterior-bg-light);
    position: relative;
    overflow: hidden;
}

.cta-section::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 600px;
    height: 600px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(172, 140, 102, 0.05), transparent 70%);
    pointer-events: none;
}

/* Transparent background for all blocks with Style Overrides */
.rct-block--transparent-bg {
    background-color: transparent !important;
}

.cta-section.rct-block--transparent-bg::before {
    display: none;
}

.cta-section__row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    align-items: center;
}

.cta-section__row.has-side-image .cta-section__media-col {
    display: flex;
    align-items: center;
}

.cta-section__row.has-side-image .cta-section__content-col {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.cta-section__row.has-side-image .cta-section__media-wrap {
    width: 100%;
}

.cta-section__row:not(.has-side-image) .cta-section__content-col {
    text-align: center;
}

.cta-section__row.has-side-image .cta-section__content-col {
    text-align: left;
}

.cta-section__content-col--glass {
    padding: 1.25rem 1.5rem;
    border-radius: 12px;
    background: var(--rct-cta-content-glass-bg, rgba(255, 255, 255, var(--rct-cta-content-glass-opacity, 0.08)));
    backdrop-filter: blur(var(--rct-cta-content-glass-blur, 12px));
    -webkit-backdrop-filter: blur(var(--rct-cta-content-glass-blur, 12px));
}

.cta-section__row:not(.has-side-image) .cta-section__content-col--glass {
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.cta-section__media-wrap {
    border-radius: 12px;
    overflow: hidden;
}

.cta-section__media-img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.cta-section__heading {
    color: var(--rct-cta-heading-color, var(--recterior-heading-color));
    font-size: var(--rct-heading-size, 2.5rem);
    font-weight: var(--rct-heading-weight, 600);
}

.cta-section .txt-rotate-keyword,
.cta-section .text-accent.txt-rotate-wrap .txt-rotate-keyword {
    color: var(--rct-cta-keyword-color, var(--recterior-accent));
}

.cta-section__description {
    color: var(--rct-cta-description-color, var(--recterior-text-muted));
    font-size: var(--rct-text-size, 1rem);
}

.cta-section__meta-label {
    color: var(--rct-cta-meta-label-color, var(--recterior-text-muted));
}

.cta-section__meta-value {
    color: var(--rct-cta-meta-value-color, var(--recterior-heading-color));
}

.cta-section__meta-icon {
    color: var(--rct-cta-meta-icon-color, var(--recterior-accent));
}

.cta-section__btn {
    background: var(--rct-cta-button-bg-color, var(--recterior-accent));
    color: var(--rct-cta-button-text-color, var(--recterior-bg, #121B1D));
    border-color: transparent;
    font-size: var(--rct-text-size, 1rem);
}

.cta-section__btn:hover,
.cta-section__btn:focus {
    background: var(--rct-cta-button-bg-color, var(--recterior-accent));
    color: var(--rct-cta-button-text-color, var(--recterior-bg, #121B1D));
    filter: brightness(1.06);
}

/* Contact cards row: equal-height columns */
.cta-section__contact-cards.row {
    align-items: stretch;
}

.cta-section__contact-cards .col-12,
.cta-section__contact-cards .col-sm-6,
.cta-section__contact-cards .col-lg-4 {
    display: flex;
}

.cta-section__contact-card--glass {
    padding: 1rem 1.25rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, var(--rct-cta-glass-opacity, 0.08));
    backdrop-filter: blur(var(--rct-cta-glass-blur, 12px));
    -webkit-backdrop-filter: blur(var(--rct-cta-glass-blur, 12px));
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

@media (min-width: 992px) {
    .cta-section__row.has-side-image.ratio-30-70 {
        grid-template-columns: 30% 70%;
    }

    .cta-section__row.has-side-image.ratio-40-60 {
        grid-template-columns: 40% 60%;
    }

    .cta-section__row.has-side-image.ratio-50-50 {
        grid-template-columns: 50% 50%;
    }

    .cta-section__row.has-side-image.is-image-left .cta-section__media-col {
        order: 1;
    }

    .cta-section__row.has-side-image.is-image-left .cta-section__content-col {
        order: 2;
    }

    .cta-section__row.has-side-image.is-image-right .cta-section__content-col {
        order: 1;
    }

    .cta-section__row.has-side-image.is-image-right .cta-section__media-col {
        order: 2;
    }

    .cta-section__row.has-side-image.is-row-reverse.is-image-left .cta-section__content-col {
        order: 1;
    }

    .cta-section__row.has-side-image.is-row-reverse.is-image-left .cta-section__media-col {
        order: 2;
    }

    .cta-section__row.has-side-image.is-row-reverse.is-image-right .cta-section__media-col {
        order: 1;
    }

    .cta-section__row.has-side-image.is-row-reverse.is-image-right .cta-section__content-col {
        order: 2;
    }
}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer {
    background-color: var(--recterior-bg);
    color: var(--recterior-text);
}

.footer-cta {
    border-bottom: 1px solid var(--recterior-border);
}

.footer-cta-heading {
    font-family: var(--recterior-font-heading);
    line-height: 1.3;
}

.footer-label {
    font-family: var(--recterior-font-body);
}

.footer-menu li {
    margin-bottom: 0.75rem;
}

.footer-menu li a {
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    font-size: 0.95rem;
    transition: var(--recterior-transition);
}

.footer-menu li a:hover {
    color: var(--recterior-white);
}

.txt-rotate-wrap {
    position: relative;
    display: inline-block;
}

.txt-rotate-keyword {
    display: inline-block;
}

/* ==========================================================================
   Scroll to Top
   ========================================================================== */
.scroll-to-top {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
    border-radius: 50%;
    font-size: 0.9rem;
    opacity: 0;
    visibility: hidden;
    transition: var(--recterior-transition);
    z-index: 1040;
    text-decoration: none;
}

.scroll-to-top.visible {
    opacity: 1;
    visibility: visible;
}

.scroll-to-top:hover {
    background-color: var(--recterior-white);
    color: var(--recterior-bg);
    transform: translateY(-3px);
}

.scroll-to-top .scroll-to-top-text {
    display: none;
}

/* ==========================================================================
   Pricing Packages Block
   ========================================================================== */
.pricing-packages {
    position: relative;
}

.pricing-packages__header {
    margin-bottom: 1.35rem;
}

.pricing-packages__title {
    margin-bottom: 0.3rem;
    color: var(--rct-pricing-header-color, var(--recterior-heading-color));
    font-size: clamp(1.55rem, 2.2vw, 2.15rem);
    line-height: 1.18;
}

.pricing-packages__subtitle {
    margin: 0;
    color: var(--rct-pricing-header-color, var(--recterior-text-muted));
    font-size: 0.94rem;
    line-height: 1.45;
}

.pricing-packages__billing-toggle {
    display: inline-flex;
    gap: 0.375rem;
    margin-top: 0.8rem;
    padding: 0.22rem;
    border: 1px solid var(--rct-pricing-card-border, rgba(255, 255, 255, 0.3));
    border-radius: 999px;
    background: var(--rct-pricing-card-bg, var(--recterior-bg-card, #0b2029));
}

.pricing-packages__billing-btn {
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--recterior-text-muted);
    padding: 0.42rem 0.9rem;
    font-size: 0.82rem;
    line-height: 1;
    transition: var(--recterior-transition);
}

.pricing-packages__billing-btn.is-active {
    background: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

.pricing-packages__grid {
    display: grid;
    grid-template-columns: repeat(var(--rct-pricing-cols, 3), minmax(0, 1fr));
    gap: var(--rct-pricing-card-gap, 0.9rem);
}

.pricing-packages--cols-2 .pricing-packages__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pricing-packages--cols-3 .pricing-packages__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pricing-packages--cols-4 .pricing-packages__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.pricing-package-card {
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: var(--rct-pricing-card-min-height, 595px);
    border-radius: 0;
    border: var(--rct-pricing-card-border-w, 1px) solid var(--rct-pricing-card-border, var(--recterior-border));
    background: var(--rct-pricing-card-bg, var(--recterior-bg-card, #1e2d30));
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.pricing-package-card.is-featured {
    background: var(--rct-pricing-featured-bg, var(--rct-pricing-card-bg, var(--recterior-bg-card, #1e2d30)));
    border-color: var(--rct-pricing-featured-border, var(--recterior-accent));
}

.pricing-package-card.is-featured .pricing-package-card__body {
    background: var(--rct-pricing-body-bg, var(--rct-pricing-featured-bg, var(--rct-pricing-card-bg, var(--recterior-bg-card, #1e2d30))));
}

.pricing-package-card__top {
    position: relative;
    text-align: center;
    padding: 0.52rem 0.6rem 0.5rem;
    background: var(--rct-pricing-header-bg, var(--recterior-bg-light, #243336));
    color: var(--rct-pricing-header-color, var(--recterior-heading-color, #ffffff));
}

.pricing-package-card__badge {
    position: absolute;
    top: -1px;
    right: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 3px 8px;
    border-radius: 2px;
    font-size: 0.62rem;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: 0.2px;
    background: var(--rct-pricing-badge-bg, var(--recterior-accent));
    color: var(--rct-pricing-badge-color, var(--recterior-accent-contrast, #121B1D));
}

.pricing-package-card__name {
    margin: 0;
    color: var(--rct-pricing-header-color, var(--recterior-heading-color, #ffffff));
    font-size: var(--rct-pricing-title-size, var(--rct-heading-size, 1.75rem));
    font-weight: var(--rct-pricing-title-weight, var(--rct-heading-weight, 500));
    line-height: 1.1;
}

.pricing-package-card__plan-subtitle {
    margin: 0.2rem 0 0;
    color: var(--rct-pricing-header-color, var(--recterior-heading-color, #ffffff));
    font-size: 0.84rem;
    opacity: 0.92;
}

.pricing-package-card__body {
    background: var(--rct-pricing-body-bg, var(--recterior-bg-card, #1e2d30));
    color: var(--rct-pricing-body-text, var(--recterior-text, #d6dfe0));
    padding: var(--rct-pricing-card-padding, 16px 14px);
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}

.pricing-package-card__price-wrap {
    margin-bottom: 0.78rem;
}

.pricing-package-card__price-note {
    display: block;
    margin: 0 0 0.2rem;
    color: var(--recterior-text-muted, #7a7a7a);
    font-size: 0.72rem;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.pricing-package-card__price {
    color: var(--rct-pricing-price-color, var(--recterior-heading-color, #ffffff));
    font-size: var(--rct-pricing-price-size, clamp(1.9rem, 2.25vw, 2.45rem));
    font-weight: 600;
    line-height: 1.05;
}

.pricing-packages.is-billing-monthly .pricing-package-card__price--yearly,
.pricing-packages.is-billing-yearly .pricing-package-card__price--monthly {
    display: none;
}

.pricing-package-card__prefix {
    margin-right: 0.14em;
    font-size: 0.42em;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.pricing-package-card__currency {
    font-size: 0.48em;
    margin-right: 0.1em;
    vertical-align: top;
}

.pricing-package-card__period {
    font-size: 0.34em;
    margin-left: 0.26em;
    color: var(--recterior-text-muted, #7a7a7a);
}

.pricing-package-card__description {
    margin: 0 0 0.7rem;
    color: var(--rct-pricing-body-text, var(--recterior-text));
    opacity: 0.9;
}

.pricing-package-card__features {
    margin: 0;
    padding: 0;
    list-style: none;
}

.pricing-package-card__features li {
    display: flex;
    align-items: flex-start;
    gap: 0.38rem;
    margin-bottom: 0.36rem;
    color: var(--rct-pricing-feature-color, var(--recterior-text));
    font-size: var(--rct-pricing-feature-size, var(--rct-text-size, 0.92rem));
    line-height: 1.4;
}

.pricing-package-card__features li.is-included {
    color: var(--rct-pricing-included-color, var(--rct-pricing-feature-color, var(--recterior-text)));
}

.pricing-package-card__features li.is-excluded {
    color: var(--rct-pricing-excluded-color, rgba(204, 213, 217, 0.68));
}

.pricing-package-card__feature-icon {
    display: inline-flex;
    width: 1rem;
    min-width: 1rem;
    justify-content: center;
    font-size: 0.78rem;
    line-height: 1.4;
    margin-top: 0.02rem;
}

.pricing-package-card__features li.is-included .pricing-package-card__feature-icon {
    color: var(--rct-pricing-included-icon, var(--recterior-accent));
}

.pricing-package-card__features li.is-excluded .pricing-package-card__feature-icon {
    color: var(--rct-pricing-excluded-icon, #8ea4ab);
}

.pricing-package-card__cta-wrap {
    margin-top: auto;
    padding-top: 0.65rem;
}

.pricing-package-card__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 40px;
    border-radius: 0;
    text-decoration: none;
    background: var(--rct-pricing-btn-bg, var(--recterior-accent));
    color: var(--rct-pricing-btn-color, var(--recterior-accent-contrast, #121B1D));
    border: 0;
    font-size: var(--rct-pricing-button-size, var(--rct-text-size, 0.86rem));
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    transition: var(--recterior-transition);
}

.pricing-package-card__btn:hover,
.pricing-package-card__btn:focus {
    background: var(--rct-pricing-btn-hover-bg, var(--rct-pricing-btn-bg, var(--recterior-accent)));
    color: var(--rct-pricing-btn-hover-color, var(--rct-pricing-btn-color, var(--recterior-accent-contrast, #121B1D)));
    filter: brightness(1.03);
}

.pricing-package-card__meta {
    background: var(--rct-pricing-footer-bg, var(--recterior-bg-light, #243336));
    color: var(--rct-pricing-footer-color, var(--recterior-text-muted, #7a7a7a));
    text-align: center;
    font-size: 0.74rem;
    line-height: 1.3;
    padding: 0.42rem 0.42rem 0.45rem;
}

.pricing-package-card__meta-line + .pricing-package-card__meta-line {
    margin-top: 0.12rem;
}

@media (max-width: 1199.98px) {
    .pricing-packages--cols-4 .pricing-packages__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .pricing-package-card {
        min-height: var(--rct-pricing-card-min-height, 560px);
    }

    .pricing-package-card__name {
        font-size: var(--rct-pricing-title-size, 1.6rem);
    }

    .pricing-package-card__price {
        font-size: var(--rct-pricing-price-size, clamp(1.75rem, 2.25vw, 2.2rem));
    }
}

@media (max-width: 991.98px) {
    .pricing-packages .pricing-packages__grid {
        grid-template-columns: repeat(var(--rct-pricing-cols-tablet, 2), minmax(0, 1fr));
    }

    .pricing-packages__header {
        margin-bottom: 1.15rem;
    }

    .pricing-packages__title {
        font-size: clamp(1.4rem, 3.1vw, 1.85rem);
    }

    .pricing-package-card {
        min-height: var(--rct-pricing-card-min-height, 525px);
    }

    .pricing-package-card__body {
        padding: 14px 13px;
    }

    .pricing-package-card__features li {
        font-size: var(--rct-pricing-feature-size, 0.88rem);
    }
}

@media (max-width: 767.98px) {
    .pricing-packages .pricing-packages__grid {
        grid-template-columns: repeat(var(--rct-pricing-cols-mobile, 1), minmax(0, 1fr));
    }

    .pricing-packages__grid {
        gap: 0.8rem;
    }

    .pricing-package-card {
        min-height: auto;
        max-width: 460px;
        margin-inline: auto;
    }

    .pricing-package-card__name {
        font-size: 1.45rem;
    }

    .pricing-package-card__top {
        padding: 0.48rem 0.55rem 0.45rem;
    }

    .pricing-package-card__body {
        padding: 14px 12px;
    }

    .pricing-package-card__price {
        font-size: var(--rct-pricing-price-size, 2rem);
    }

    .pricing-package-card__features li {
        font-size: var(--rct-pricing-feature-size, 0.86rem);
        margin-bottom: 0.32rem;
    }

    .pricing-package-card__meta {
        font-size: 0.72rem;
    }
}

/* ==========================================================================
   Contact Page
   ========================================================================== */
.contact-form .form-control,
.contact-form .form-select {
    background-color: transparent;
    border: none;
    border-bottom: 1px solid var(--recterior-border);
    border-radius: 0;
    color: var(--recterior-white);
    padding: 0.75rem 0;
    font-size: 0.95rem;
    transition: var(--recterior-transition);
}

.contact-form .form-control:focus,
.contact-form .form-select:focus {
    background-color: transparent;
    border-bottom-color: var(--recterior-accent);
    box-shadow: none;
    color: var(--recterior-white);
}

.contact-form .form-control::placeholder {
    color: var(--recterior-text-muted);
}

.contact-form .form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23AC8C66' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

.contact-form .form-select option {
    background-color: var(--recterior-bg);
    color: var(--recterior-white);
}

.contact-form .form-check-input {
    background-color: transparent;
    border-color: var(--recterior-border);
}

.contact-form .form-check-input:checked {
    background-color: var(--recterior-accent);
    border-color: var(--recterior-accent);
}

.contact-form .form-check-label {
    color: var(--recterior-text-muted);
    font-size: 0.85rem;
}

.contact-info-card {
    padding: 2rem;
    border: 1px solid var(--recterior-border);
    border-radius: 0.5rem;
    height: 100%;
    transition: var(--recterior-transition);
}

.contact-info-card:hover {
    border-color: var(--recterior-accent);
}

.contact-info-card h5 {
    font-family: var(--recterior-font-body);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--recterior-text-muted);
    margin-bottom: 1rem;
}

.contact-info-card p {
    color: var(--recterior-white);
    font-size: 1rem;
    margin-bottom: 0;
}

/* ==========================================================================
   About Page
   ========================================================================== */
.about-hero {
    padding: 10rem 0 5rem;
}

.about-hero .hero-title {
    font-size: clamp(2rem, 4vw, 3.5rem);
}

.about-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2rem;
}

.about-badges .badge-item {
    background-color: rgba(172, 140, 102, 0.15);
    color: var(--recterior-accent);
    padding: 0.4rem 1rem;
    border-radius: 2rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ==========================================================================
   Projects Page
   ========================================================================== */
.projects-hero {
    padding: 10rem 0 4rem;
}

/* ==========================================================================
   Single Portfolio — Hero Carousel
   ========================================================================== */
.pf-hero-wrapper {
    width: 100%;
    max-width: 100%;
}

.pf-hero-wrapper.container-fluid {
    padding-left: 0;
    padding-right: 0;
}

.pf-hero-carousel {
    width: 100%;
    overflow: hidden;
}

.pf-hero-block-wrapper {
    width: 100%;
}

.pf-hero-block-wrapper .hero-section,
.pf-hero-block-wrapper .flickity-slideshow {
    max-width: none;
}

/* Full-width hero when full page option is enabled */
.pf-full-page .pf-hero-carousel--full-width {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.pf-hero-carousel__track {
    width: 100%;
}

.pf-hero-carousel__slide {
    width: 100%;
    height: 70vh;
    min-height: 400px;
}

.pf-hero-carousel__slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pf-hero-carousel .flickity-prev-next-button {
    width: 50px;
    height: 50px;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 0;
}

.pf-hero-carousel .flickity-prev-next-button:hover {
    background: var(--recterior-accent);
}

.pf-hero-carousel .flickity-prev-next-button .flickity-button-icon {
    fill: #1a1a1a;
}

.pf-hero-carousel .flickity-prev-next-button:hover .flickity-button-icon {
    fill: var(--recterior-accent-contrast, #121B1D);
}

.pf-hero-carousel .flickity-page-dots {
    bottom: 20px;
}

.pf-hero-carousel .flickity-page-dots .dot {
    background: rgba(255, 255, 255, 0.5);
}

.pf-hero-carousel .flickity-page-dots .dot.is-selected {
    background: #fff;
}

.pf-hero-carousel .flickity-viewport {
    height: 100% !important;
}

.pf-hero-carousel .flickity-slider {
    height: 100%;
}

/* ==========================================================================
   Single Portfolio — Sidebar + Content Layout
   ========================================================================== */
.pf-content {
    padding-top: 60px;
    padding-bottom: 60px;
}

.pf-content .row.align-items-start {
    align-items: flex-start;
}

.pf-sidebar,
.pf-main-content {
    padding-top: 0;
}

.pf-sidebar {
    position: sticky;
    top: 100px;
}

.pf-sidebar__title {
    font-family: var(--recterior-font-heading);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    color: var(--recterior-heading-color);
    margin-bottom: 16px;
    line-height: 1.3;
}

.pf-sidebar__desc {
    color: var(--recterior-text);
    font-size: 0.95rem;
    line-height: 1.7;
    margin-bottom: 24px;
}

.pf-sidebar__details {
    background-color: #F7F8FA;
    border-radius: 5px;
    padding: 28px;
    margin-bottom: 24px;
}

.pf-sidebar__meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid var(--recterior-border, rgba(0, 0, 0, 0.08));
    font-size: 0.9rem;
}

.pf-sidebar__meta-row:last-child {
    border-bottom: none;
}

.pf-sidebar__label {
    color: #7a7a7a;
    font-weight: 400;
}

.pf-sidebar__value {
    color: var(--recterior-heading-color);
    font-weight: 600;
}

.pf-sidebar__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #2E2E2E;
    color: #fff;
    padding: 14px 28px;
    border-radius: 5px;
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.3s ease, transform 0.2s ease;
    width: 100%;
    justify-content: center;
}

.pf-sidebar__cta:hover {
    background: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
    transform: translateY(-1px);
}

.pf-main-content {
    color: var(--recterior-text);
    line-height: 1.8;
}

.pf-main-content h2,
.pf-main-content h3,
.pf-main-content h4 {
    color: var(--recterior-heading-color);
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.pf-main-content p {
    margin-bottom: .5rem;
    margin-top: .5rem;
}

.pf-main-content img {
    max-width: 100%;
    height: auto;
    border-radius: 5px;
    margin: 1rem 0;
}

.rct-project-meta__card {
    max-width: 760px;
}

.rct-project-meta__title {
    font-family: var(--recterior-font-heading);
    color: var(--recterior-heading-color);
    font-size: clamp(1.2rem, 2.1vw, 1.55rem);
    margin: 0 0 0.75rem;
}

.rct-project-meta__description {
    color: var(--recterior-text-muted);
    margin: 0 0 1.1rem;
    line-height: 1.65;
}

.rct-project-meta__row:first-child {
    border-top: none;
    padding-top: 0;
}

.rct-project-meta__value a {
    color: inherit;
    text-decoration: none;
    overflow-wrap: anywhere;
}

.rct-project-meta__value a:hover,
.rct-project-meta__value a:focus {
    color: var(--recterior-accent);
}

/* Portfolio Navigation */
.portfolio-navigation {
    padding: 40px 0;
    margin-top: 40px;
    border-top: 1px solid var(--recterior-border);
}

.pf-nav-link {
    gap: 14px;
    max-width: 100%;
}

.pf-nav-link__text-wrap {
    display: inline-flex;
    flex-direction: column;
}

.pf-nav-link__label {
    display: block;
    font-size: 0.8rem;
    color: var(--recterior-text-muted);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.pf-nav-link__title {
    display: block;
    font-weight: 700;
    color: var(--recterior-heading-color);
    font-size: 1.1rem;
    transition: color 0.3s ease;
    line-height: 1.3;
    word-break: break-word;
}

.pf-nav-link:hover .pf-nav-link__title {
    color: var(--recterior-accent);
}

.pf-nav-link__icon {
    font-size: 0.95rem;
    color: var(--recterior-heading-color);
    transition: color 0.3s ease, transform 0.3s ease;
    flex-shrink: 0;
}

.pf-nav-link--prev:hover .pf-nav-link__icon {
    color: var(--recterior-accent);
    transform: translateX(-2px);
}

.pf-nav-link--next:hover .pf-nav-link__icon {
    color: var(--recterior-accent);
    transform: translateX(2px);
}

@media (max-width: 991.98px) {
    .pf-hero-carousel__slide {
        height: 50vh;
    }

    .pf-sidebar {
        position: static;
        margin-bottom: 2rem;
    }

    .portfolio-navigation {
        padding: 24px 0;
        margin-top: 24px;
    }

    .pf-nav-link {
        gap: 10px;
    }

    .pf-nav-link__label {
        font-size: 0.7rem;
    }

    .pf-nav-link__title {
        font-size: 0.95rem;
    }
}

@media (max-width: 767.98px) {
    .pf-hero-carousel__slide {
        height: 40vh;
        min-height: 280px;
    }

    .portfolio-navigation .col-6 {
        width: 100%;
        text-align: left !important;
    }

    .portfolio-navigation .col-6 + .col-6 {
        margin-top: 16px;
    }
}

/* ==========================================================================
   Shared Single Sidebar Blocks
   ========================================================================== */
.rct-single-sidebar {
    display: grid;
    gap: 22px;
}

.rct-single-sidebar--bottom {
    display: block;
    position: static;
    width: 100%;
}

.rct-single-sidebar--bottom .rct-sidebar-bottom__row {
    display: flex;
    flex-wrap: wrap;
    --rct-sidebar-bottom-gap: 1rem;
    gap: var(--rct-sidebar-bottom-gap);
    align-items: stretch;
    width: 100%;
    margin: 0;
    padding: 0;
}

@media (min-width: 576px) {
    .rct-single-sidebar--bottom .rct-sidebar-bottom__row {
        --rct-sidebar-bottom-gap: 1.25rem;
    }
}

@media (min-width: 992px) {
    .rct-single-sidebar--bottom .rct-sidebar-bottom__row {
        --rct-sidebar-bottom-gap: 1.5rem;
    }
}

.rct-single-sidebar--bottom .rct-sidebar-bottom__col {
    flex: 1 1 100%;
    min-width: 100%;
    max-width: 100%;
    display: flex;
    flex-direction: column;
}

@media (min-width: 576px) {
    .rct-single-sidebar--bottom .rct-sidebar-bottom__col {
        flex: 1 1 calc((100% - var(--rct-sidebar-bottom-gap)) / 2);
        min-width: calc((100% - var(--rct-sidebar-bottom-gap)) / 2);
    }
}

@media (min-width: 992px) {
    .rct-single-sidebar--bottom .rct-sidebar-bottom__col {
        flex: 1 1 calc((100% - (2 * var(--rct-sidebar-bottom-gap))) / 3);
        min-width: calc((100% - (2 * var(--rct-sidebar-bottom-gap))) / 3);
    }
}

.rct-single-sidebar--bottom .rct-sidebar-block {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.rct-single-sidebar--bottom .rct-sidebar-block__inner {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.rct-single-sidebar--bottom .rct-sidebar-block--quote .rct-sidebar-block__inner {
    flex: none;
}

.rct-single-sidebar--bottom .rct-sidebar-block__title {
    font-size: clamp(1.1rem, 2vw, 1.3rem);
}

.rct-single-sidebar--bottom .rct-sidebar-block__desc {
    font-size: clamp(0.875rem, 1.5vw, 0.95rem);
}

.rct-single-sidebar--bottom .rct-sidebar-info__image-wrap {
    flex-shrink: 0;
}

.rct-single-sidebar--bottom .rct-sidebar-info__image {
    width: 100%;
    height: auto;
    max-width: 100%;
    object-fit: cover;
}

@media (min-width: 576px) {
    .rct-single-sidebar--bottom .rct-sidebar-block--info .rct-sidebar-block__inner {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 0.5rem 0.85rem;
        align-items: start;
    }

    .rct-single-sidebar--bottom .rct-sidebar-block--info .rct-sidebar-info__image-wrap {
        grid-column: 1;
        grid-row: 1 / span 3;
        width: 100%;
        margin-bottom: 0 !important;
    }

    .rct-single-sidebar--bottom .rct-sidebar-block--info .rct-sidebar-info__image-wrap ~ * {
        grid-column: 2;
    }

    .rct-single-sidebar--bottom .rct-sidebar-block--info .rct-sidebar-block__title {
        margin-bottom: 0.2rem;
    }

    .rct-single-sidebar--bottom .rct-sidebar-block--info .rct-sidebar-block__desc {
        margin-bottom: 0.4rem;
        line-height: 1.55;
    }
}

@media (min-width: 992px) {
    .rct-single-sidebar--bottom .rct-sidebar-block--info .rct-sidebar-block__inner {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 0.6rem 1rem;
    }
}

.rct-single-sidebar--bottom .rct-sidebar-block--html .rct-sidebar-block__inner {
    flex: 1;
}

.rct-single-sidebar--bottom .rct-sidebar-block--html .rct-sidebar-block__inner > *:last-child {
    margin-bottom: 0;
}

.rct-single-sidebar--bottom .rct-sidebar-block__inner {
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.rct-single-sidebar--bottom .rct-sidebar-quote-form .form-control {
    font-size: clamp(0.875rem, 1.5vw, 1rem);
}

.rct-single-sidebar--bottom .rct-sidebar-quote-form__submit {
    font-size: clamp(0.8rem, 1.5vw, 0.85rem);
}


.rct-single-sidebar.is-sticky {
    position: sticky;
    top: calc(6.5rem + env(safe-area-inset-top, 0px));
}

.admin-bar .rct-single-sidebar.is-sticky {
    top: calc(6.5rem + 32px + env(safe-area-inset-top, 0px));
}

.rct-sidebar-block {
    border: 1px solid var(--recterior-border);
    background: var(--recterior-bg-light, #ffffff);
}

.rct-sidebar-block__inner {
    padding: 22px;
}

.rct-sidebar-block__title {
    font-family: var(--recterior-font-heading);
    font-size: 1.3rem;
    line-height: 1.3;
    margin-bottom: 10px;
    color: var(--recterior-heading-color);
}

.rct-sidebar-block__desc {
    margin-bottom: 14px;
    color: var(--recterior-text-muted);
    font-size: 0.95rem;
    line-height: 1.7;
}

.rct-sidebar-info__image-wrap {
    overflow: hidden;
}

.rct-sidebar-info__image {
    width: 100%;
    height: auto;
    display: block;
}

.rct-sidebar-info__link {
    color: var(--recterior-accent);
    font-weight: 600;
    text-decoration: none;
}

.rct-sidebar-info__link:hover {
    color: var(--recterior-heading-color);
}

.rct-sidebar-quote-form .form-control {
    background: var(--recterior-bg, transparent);
    border: 1px solid var(--recterior-border);
    color: var(--recterior-heading-color);
    padding: 0.7rem 0.85rem;
}

.rct-sidebar-quote-form .form-control::placeholder {
    color: var(--recterior-text-muted);
}

.rct-sidebar-quote-form .form-control:focus {
    border-color: var(--recterior-accent);
    box-shadow: none;
    background: var(--recterior-bg, transparent);
}

.rct-sidebar-quote-form__submit {
    background-color: var(--recterior-accent);
    border-color: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    padding: 0.75rem 0.9rem;
}

.rct-sidebar-quote-form__submit:hover,
.rct-sidebar-quote-form__submit:focus {
    background-color: var(--recterior-theme-bg);
    border-color: var(--recterior-theme-bg);
    color: #fff;
}

.rct-sidebar-quote-form__response {
    min-height: 1.2em;
    font-size: 0.9rem;
}

[data-bs-theme="light"] .rct-sidebar-block {
    background: #ffffff;
}

[data-bs-theme="light"] .rct-sidebar-quote-form .form-control {
    background: #ffffff;
}

[data-bs-theme="dark"] .rct-sidebar-block {
    background: rgba(255, 255, 255, 0.04);
}

[data-bs-theme="dark"] .rct-sidebar-quote-form .form-control {
    background: rgba(255, 255, 255, 0.02);
}

@media (max-width: 991.98px) {
    .rct-single-sidebar.is-sticky {
        position: static;
        margin-top: 2rem;
    }
}

@media (max-width: 782px) {
    .admin-bar .rct-single-sidebar.is-sticky {
        top: calc(6.5rem + 46px + env(safe-area-inset-top, 0px));
    }
}

/* ==========================================================================
   FAQ Accordion Block
   ========================================================================== */
.rct-faq-accordion {
    --rct-faq-fallback-bg: transparent;
    --rct-faq-fallback-active-bg: transparent;
    --rct-faq-fallback-color: var(--recterior-heading-color);
    --rct-faq-fallback-active-color: var(--recterior-heading-color);
    --rct-faq-fallback-active-border-color: var(--recterior-border);
}

.rct-faq-accordion.rct-faq-accordion--page-width > .container {
    padding-left: 0;
    padding-right: 0;
}

.rct-faq-accordion__heading {
    font-family: var(--recterior-font-heading);
    font-size: var(--rct-heading-size, clamp(1.5rem, 3vw, 1.75rem));
    font-weight: var(--rct-heading-weight, 700);
    color: var(--recterior-heading-color);
    margin-bottom: var(--rct-faq-heading-gap, 24px);
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-header {
    margin: 0;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item {
    border: none;
    margin-bottom: var(--rct-faq-item-gap, 12px);
    border-radius: 4px !important;
    overflow: hidden;
    background-color: var(--rct-faq-item-bg, var(--rct-faq-fallback-bg));
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item:last-child {
    margin-bottom: 0;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-header > .accordion-button {
    background-color: var(--rct-faq-item-bg, var(--rct-faq-fallback-bg));
    color: var(--rct-faq-item-color, var(--rct-faq-fallback-color));
    font-size: var(--rct-text-size, 1rem);
    font-weight: var(--rct-heading-weight, 700);
    padding: var(--rct-faq-question-padding, 16px 20px);
    border: 1px solid var(--recterior-border);
    border-radius: 4px !important;
    box-shadow: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-header > .accordion-button::after {
    display: none;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-header > .accordion-button .accordion-button__icon {
    font-size: 14px;
    transition: transform 0.3s ease;
    flex-shrink: 0;
    margin-left: var(--rct-faq-icon-gap, 12px);
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-header > .accordion-button:not(.collapsed) {
    background-color: var(--rct-faq-item-active-bg, var(--rct-faq-item-bg, var(--rct-faq-fallback-active-bg)));
    color: var(--rct-faq-item-active-color, var(--rct-faq-item-color, var(--rct-faq-fallback-active-color)));
    border-color: var(--rct-faq-item-active-border-color, var(--rct-faq-fallback-active-border-color));
    border-radius: 4px 4px 0 0 !important;
}

.rct-faq-accordion.is-icon-arrow .rct-faq-accordion__list > .accordion-item > .accordion-header > .accordion-button:not(.collapsed) .accordion-button__icon {
    transform: rotate(180deg);
    color: inherit;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-header > .accordion-button:focus-visible {
    outline: 2px solid var(--recterior-accent, #AC8C66);
    outline-offset: 1px;
    box-shadow: inset 0 0 0 2px var(--recterior-accent, #AC8C66);
}

@media (forced-colors: active) {
    .rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-header > .accordion-button:focus-visible {
        outline: 2px solid CanvasText;
        box-shadow: none;
    }
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-collapse {
    border: none;
    border-radius: 0 0 4px 4px;
    overflow: hidden;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-collapse.show,
.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-collapse.collapsing {
    border: 1px solid var(--rct-faq-item-active-border-color, var(--rct-faq-fallback-active-border-color));
    border-top: none;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-collapse > .accordion-body {
    padding: var(--rct-faq-question-padding, 16px 20px);
    color: var(--rct-faq-item-active-color, var(--rct-faq-item-color, var(--recterior-text-muted)));
    font-size: var(--rct-text-size, 1rem);
    line-height: 1.7;
    background: transparent;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-collapse > .accordion-body > .accordion-body__content > :last-child {
    margin-bottom: 0;
}

.rct-faq-accordion .rct-faq-accordion__list > .accordion-item > .accordion-collapse > .accordion-body > .accordion-body__content p {
    margin-top: 0;
    margin-bottom: 1rem;
}

.rct-faq-accordion.is-icon-plusminus .rct-faq-accordion__list .accordion-button__icon {
    width: 1rem;
    height: 1rem;
    position: relative;
    font-size: 1rem;
}

.rct-faq-accordion.is-icon-plusminus .rct-faq-accordion__list .accordion-button__icon i {
    display: none;
}

.rct-faq-accordion.is-icon-plusminus .rct-faq-accordion__list .accordion-button__icon::before,
.rct-faq-accordion.is-icon-plusminus .rct-faq-accordion__list .accordion-button__icon::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 0.8rem;
    height: 2px;
    background: currentColor;
    transform: translate(-50%, -50%);
    transition: opacity 0.25s ease;
}

.rct-faq-accordion.is-icon-plusminus .rct-faq-accordion__list .accordion-button__icon::after {
    transform: translate(-50%, -50%) rotate(90deg);
}

.rct-faq-accordion.is-icon-plusminus .rct-faq-accordion__list .accordion-button:not(.collapsed) .accordion-button__icon::after {
    opacity: 0;
}

/* ==========================================================================
   Feature Highlight Block
   ========================================================================== */
.rct-feature-highlight__wrap {
    display: flex;
    border: 1px solid var(--recterior-border, #EBEBEB);
    border-radius: 5px;
    overflow: hidden;
}

.rct-feature-highlight__info {
    flex: 0 0 55%;
    max-width: 55%;
    padding: 35px;
    border-right: 1px solid var(--recterior-border, #EBEBEB);
}

.rct-feature-highlight__title {
    font-family: var(--recterior-font-heading);
    font-size: clamp(1.25rem, 2.5vw, 1.5rem);
    font-weight: 700;
    color: var(--recterior-heading-color);
    margin-bottom: 16px;
}

.rct-feature-highlight__desc {
    color: var(--recterior-text);
    font-size: 0.95rem;
    line-height: 1.7;
    margin-bottom: 24px;
}

.rct-feature-highlight__btn {
    display: inline-block;
    background: #2E2E2E;
    color: #ffffff;
    padding: 14px 36px;
    border-radius: 5px;
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.3s ease;
}

.rct-feature-highlight__btn:hover {
    background: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

.rct-feature-highlight__checklist {
    flex: 0 0 45%;
    max-width: 45%;
    padding: 35px;
    display: flex;
    align-items: center;
}

.rct-feature-highlight__checklist ul {
    list-style: none;
    padding: 0;
    margin: 0;
    width: 100%;
}

.rct-feature-highlight__checklist li {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    font-size: 0.95rem;
    color: var(--recterior-text, #525252);
}

.rct-feature-highlight__checklist li i {
    color: var(--recterior-accent);
    font-size: 1rem;
    flex-shrink: 0;
}

@media (max-width: 767.98px) {
    .rct-feature-highlight__wrap {
        flex-direction: column;
    }

    .rct-feature-highlight__info,
    .rct-feature-highlight__checklist {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .rct-feature-highlight__info {
        border-right: none;
        border-bottom: 1px solid var(--recterior-border, #EBEBEB);
    }
}

/* ==========================================================================
   Before / After Image Comparison — Modern UI/UX
   ========================================================================== */
.rct-before-after .rct-ba-container {
    position: relative;
    overflow: hidden;
    margin: 0;
    line-height: 0;
    user-select: none;
    -webkit-user-select: none;
    border-radius: 8px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15);
}

.rct-ba-before {
    display: block;
    width: 100%;
    height: auto;
    pointer-events: none;
    vertical-align: middle;
}

.rct-ba-after {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
}

.rct-ba-handle {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 4px;
    background: var(--recterior-accent, #AC8C66);
    transform: translateX(-50%);
    cursor: col-resize;
    z-index: 5;
    touch-action: none;
    transition: background-color var(--recterior-transition-fast, 0.2s ease);
}

.rct-ba-handle:hover,
.rct-ba-handle:focus-visible,
.rct-ba-container.is-dragging .rct-ba-handle {
    background: var(--recterior-accent, #AC8C66);
}

.rct-ba-handle:focus {
    outline: none;
}

.rct-ba-handle:focus-visible .rct-ba-handle__grip {
    box-shadow: 0 0 0 3px var(--recterior-bg, #121B1D), 0 2px 12px rgba(0, 0, 0, 0.3);
}

.rct-ba-handle__grip {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--recterior-white, #ffffff);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
    color: var(--recterior-accent, #AC8C66);
    cursor: col-resize;
    transition: transform var(--recterior-transition-fast, 0.2s ease), box-shadow var(--recterior-transition-fast, 0.2s ease);
}

.rct-ba-handle__grip:hover {
    transform: translate(-50%, -50%) scale(1.05);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

.rct-ba-handle__grip svg {
    width: 12px;
    height: 24px;
}

.rct-ba-container.is-dragging {
    cursor: col-resize;
}

.rct-ba-container.is-dragging .rct-ba-handle__grip {
    transform: translate(-50%, -50%) scale(1.08);
}

.rct-ba-label {
    position: absolute;
    padding: 8px 20px;
    background: rgba(0, 0, 0, 0.6);
    color: #ffffff;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.4;
    z-index: 3;
    pointer-events: none;
    letter-spacing: 0.5px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.rct-ba-label--before {
    top: 24px;
    left: 24px;
}

.rct-ba-label--after {
    top: 24px;
    right: 24px;
}

@media (max-width: 767.98px) {
    .rct-ba-label {
        font-size: 12px;
        padding: 6px 14px;
        top: 16px;
    }

    .rct-ba-label--before {
        left: 16px;
        top: 16px;
    }

    .rct-ba-label--after {
        right: 16px;
        top: 16px;
    }

    .rct-ba-handle__grip {
        width: 40px;
        height: 40px;
    }

    .rct-ba-handle__grip svg {
        width: 10px;
        height: 20px;
    }
}

/* ==========================================================================
   Simple Testimonials
   ========================================================================== */
.rct-st-inner {
    max-width: 50%;
    margin: 0 auto;
    text-align: center;
    position: relative;
}

.rct-st-heading {
    font-family: var(--recterior-font-heading);
    font-size: var(--rct-st-heading-size, var(--rct-heading-size, 24px));
    font-weight: var(--rct-st-heading-weight, 700);
    color: var(--recterior-heading-color);
    margin-bottom: 1em;
    text-align: var(--rct-st-heading-align, center);
}

.rct-st-carousel {
    position: relative;
}

.rct-st-slide {
    width: 100%;
    text-align: var(--rct-st-content-align, center);
}

.rct-st-slide h4 {
    font-size: var(--rct-st-title-size, 1.125rem);
    font-weight: var(--rct-st-title-weight, 600);
    color: var(--recterior-heading-color);
}

.rct-st-slide p {
    font-size: var(--rct-st-text-size, var(--rct-text-size, 17px));
    font-weight: var(--rct-st-text-weight, 400);
    line-height: 1.52em;
    color: var(--recterior-heading-color);
    text-align: var(--rct-st-content-align, center);
    margin: 0;
}

.rct-st-meta {
    margin-top: 1.1rem;
    color: var(--recterior-text-muted);
    display: flex;
    flex-direction: column;
    align-items: var(--rct-st-author-justify, center);
    text-align: var(--rct-st-author-align, var(--rct-st-content-align, center));
}

.rct-st-author {
    display: block;
    color: var(--recterior-heading-color);
    font-weight: 600;
    line-height: 1.35;
}

.rct-st-role {
    display: block;
    margin-top: 0.2rem;
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.rct-st-arrows-angle .rct-st-carousel .flickity-prev-next-button .flickity-button-icon,
.rct-st-arrows-line .rct-st-carousel .flickity-prev-next-button .flickity-button-icon {
    display: none;
}

.rct-st-arrows-angle .rct-st-carousel .flickity-prev-next-button::before,
.rct-st-arrows-line .rct-st-carousel .flickity-prev-next-button::before {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: var(--recterior-heading-color, #000);
    font-size: 34px;
    line-height: 1;
}

.rct-st-arrows-angle .rct-st-carousel .flickity-prev-next-button.previous::before {
    content: '\2039';
}

.rct-st-arrows-angle .rct-st-carousel .flickity-prev-next-button.next::before {
    content: '\203A';
}

.rct-st-arrows-line .rct-st-carousel .flickity-prev-next-button.previous::before {
    content: '\2190';
}

.rct-st-arrows-line .rct-st-carousel .flickity-prev-next-button.next::before {
    content: '\2192';
}

.rct-st-carousel .flickity-prev-next-button {
    width: 40px;
    height: 40px;
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

.rct-st-carousel .flickity-prev-next-button.previous {
    left: -60px;
}

.rct-st-carousel .flickity-prev-next-button.next {
    right: -60px;
}

.rct-st-carousel .flickity-prev-next-button .flickity-button-icon {
    fill: var(--recterior-heading-color, #000);
    transition: opacity 0.3s ease;
}

.rct-st-carousel .flickity-prev-next-button:hover .flickity-button-icon {
    opacity: 0.5;
}

.rct-st-carousel .flickity-page-dots {
    position: relative;
    bottom: auto;
    margin-top: 30px;
}

.rct-st-carousel .flickity-page-dots .dot {
    width: 8px;
    height: 8px;
    margin: 0 5px;
    background: var(--recterior-heading-color, #000);
    opacity: 0.25;
    transition: opacity 0.3s ease;
}

.rct-st-carousel .flickity-page-dots .dot.is-selected {
    opacity: 1;
}

.rct-simple-testimonials {
    padding-top: 60px;
    padding-bottom: 110px;
}

.rct-simple-testimonials.rct-simple-testimonials--page-width > .container {
    padding-left: 0;
    padding-right: 0;
}

@media (max-width: 1024px) {
    .rct-st-inner {
        max-width: 100%;
    }

    .rct-st-carousel .flickity-prev-next-button.previous {
        left: -10px;
    }

    .rct-st-carousel .flickity-prev-next-button.next {
        right: -10px;
    }

    .rct-simple-testimonials {
        padding-top: 70px;
        padding-bottom: 30px;
    }
}

@media (max-width: 767.98px) {
    .rct-simple-testimonials {
        padding-top: 70px;
        padding-bottom: 40px;
    }

    .rct-st-carousel .flickity-prev-next-button {
        display: none;
    }

    .rct-st-slide p {
        font-size: 15px;
    }
}

/* ==========================================================================
   Related Posts (Single Blog)
   ========================================================================== */
.rct-related-posts {
    margin-top: 3rem;
    overflow: hidden;
}

.rct-related-posts__heading {
    font-family: var(--recterior-font-heading);
    color: var(--recterior-heading-color, #fff);
}

/* Equal-height cards: fixed title/excerpt heights with ellipsis, button always visible */
.rct-related-posts .card {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.rct-related-posts__title a {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.35;
}

.rct-related-posts__excerpt {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.5;
}

.rct-related-posts .card-img-top {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 16 / 10;
    flex-shrink: 0;
    transition: opacity var(--recterior-transition-fast, 0.2s ease);
}

.rct-related-posts__img-placeholder {
    aspect-ratio: 16 / 10;
    background: rgba(255, 255, 255, 0.05);
    flex-shrink: 0;
}

.rct-related-posts__img-link {
    display: block;
    overflow: hidden;
}

.rct-related-posts__img-link:hover .card-img-top {
    opacity: 0.9;
}

.rct-related-posts .card-title a:hover {
    color: var(--recterior-accent) !important;
}

.rct-related-posts-slider {
    position: relative;
    overflow: hidden;
    min-height: 320px;
}

.rct-related-posts__slide {
    width: 100%;
    padding: 0 8px;
    box-sizing: border-box;
}

@media (min-width: 576px) {
    .rct-related-posts__slide {
        width: 50%;
    }
}

@media (min-width: 992px) {
    .rct-related-posts__slide {
        width: 33.333%;
    }
}

.rct-related-posts-slider .flickity-prev-next-button {
    width: 40px;
    height: 40px;
    background: transparent;
    border: none;
    border-radius: 0;
}

.rct-related-posts-slider .flickity-prev-next-button.previous {
    left: -10px;
}

.rct-related-posts-slider .flickity-prev-next-button.next {
    right: -10px;
}

.rct-related-posts-slider .flickity-prev-next-button .flickity-button-icon {
    fill: var(--recterior-heading-color, #fff);
}

.rct-related-posts-slider .flickity-prev-next-button:hover .flickity-button-icon {
    opacity: 0.7;
}

.rct-related-posts-slider .flickity-page-dots {
    margin-top: 1.5rem;
}

.rct-related-posts-slider .flickity-page-dots .dot {
    background: var(--recterior-heading-color, #fff);
    opacity: 0.25;
}

.rct-related-posts-slider .flickity-page-dots .dot.is-selected {
    opacity: 1;
}

@media (max-width: 767.98px) {
    .rct-related-posts-slider .flickity-prev-next-button {
        display: none;
    }

    .rct-related-posts__slide {
        padding: 0 6px;
    }

    .rct-related-posts {
        margin-top: 2.5rem;
    }
}

/* ==========================================================================
   404 Page
   ========================================================================== */
.error-404 {
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.error-404 .error-code {
    font-size: 8rem;
    font-weight: 700;
    color: var(--recterior-accent);
    line-height: 1;
    margin-bottom: 1rem;
    font-family: var(--recterior-font-heading);
}

/* ==========================================================================
   Animations
   ========================================================================== */
.fade-up {
    opacity: 0;
    transform: translate3d(0, 50px, 0);
    transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.fade-up.animated {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.fade-in {
    opacity: 0;
    transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.fade-in.animated {
    opacity: 1;
}

.reveal-up {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
}

.reveal-scale {
    opacity: 0;
    transform: scale(0.85);
}

/* ==========================================================================
   WordPress Specific
   ========================================================================== */
.wp-caption {
    max-width: 100%;
}

.wp-caption-text {
    color: var(--recterior-text-muted);
    font-size: 0.85rem;
    margin-top: 0.5rem;
}

.alignleft {
    float: left;
    margin-right: 1.5rem;
    margin-bottom: 1.5rem;
}

.alignright {
    float: right;
    margin-left: 1.5rem;
    margin-bottom: 1.5rem;
}

.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5rem;
}

.gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

/* WordPress Pagination */
.pagination-wrap .nav-links {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.pagination-wrap .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    width: auto;
    height: 2.5rem;
    padding: 0 0.7rem;
    border: 1px solid var(--recterior-border);
    color: var(--recterior-text);
    text-decoration: none;
    transition: var(--recterior-transition);
    white-space: nowrap;
}

.pagination-wrap a.page-numbers.prev,
.pagination-wrap a.page-numbers.next {
    min-width: 5.5rem;
    padding: 0 1rem;
}

.pagination-wrap .page-numbers.current,
.pagination-wrap .page-numbers:hover {
    background-color: var(--recterior-accent);
    border-color: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

/* ==========================================================================
   Responsive
   ========================================================================== */
/* (Bootstrap collapse responsive styles removed — fullscreen menu is used instead) */

@media (max-width: 991.98px) {
    .services-tabs .nav-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
        justify-content: flex-start !important;
    }

    .services-tabs .nav-tabs .nav-link {
        white-space: nowrap;
    }

    .services-tabs.tabs-vertical .services-tabs__tabs-shell {
        grid-template-columns: minmax(180px, min(var(--rct-st-vertical-nav-width, 260px), 34%)) minmax(0, 1fr);
        gap: 1.25rem;
    }

    .services-tabs.tabs-vertical .nav-tabs {
        flex-direction: column;
        align-items: stretch;
        border-right: 0;
        border-bottom: 0;
        padding-right: 0;
    }

    .services-tabs.tabs-vertical .nav-tabs .nav-link {
        border-right: 0;
        border-bottom: 2px solid transparent;
        text-align: left;
        padding: 0.85rem 0.35rem;
    }

    .services-tabs.tabs-vertical .nav-tabs .nav-link.active {
        border-right-color: transparent;
        border-bottom-color: var(--recterior-accent);
    }

    .services-tabs__pane .services-tabs__content-col {
        text-align: center;
    }

    .services-tabs__media-col {
        position: relative;
        top: auto;
    }

    .services-tabs__media-wrap {
        position: relative;
        top: auto;
    }

    .gallery {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 767.98px) {
    .services-tabs.tabs-vertical .services-tabs__tabs-shell {
        grid-template-columns: 1fr;
    }

    .services-tabs.tabs-vertical .nav-tabs {
        flex-direction: row;
        border-bottom: 1px solid var(--recterior-border);
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
    }

    .services-tabs.tabs-vertical .nav-tabs .nav-link {
        text-align: center;
        white-space: nowrap;
        padding: 0.85rem 1rem;
    }

    .hero-title {
        font-size: var(--rct-hero-title-size, clamp(2rem, 4vw, 3rem));
    }

    .hero-slide {
        padding: 6rem 0 4rem;
    }

    .hero-slide--center {
        padding: 6rem 0;
    }

    .counter-box .counter-value {
        font-size: 2.25rem;
    }

    .experience-counter .counter-value {
        font-size: 3rem;
    }

    .portfolio-grid {
        gap: 1rem;
    }

    .footer-cta-heading {
        font-size: 1.75rem;
    }

    .gallery {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Custom Cursor
   ========================================================================== */
body.rct-custom-cursor,
body.rct-custom-cursor a,
body.rct-custom-cursor button,
body.rct-custom-cursor input,
body.rct-custom-cursor textarea,
body.rct-custom-cursor select {
    cursor: none !important;
}

/* Custom Cursor — single dot, follows mouse directly, CSS transitions for states */
.rct-cursor {
    position: fixed;
    top: 0;
    left: 0;
    width: 8px;
    height: 8px;
    margin-left: -4px;
    margin-top: -4px;
    border-radius: 50%;
    background-color: var(--recterior-white);
    pointer-events: none;
    z-index: 99999;
    opacity: 0;
    will-change: transform;
    transition: width 0.25s ease,
                height 0.25s ease,
                margin 0.25s ease,
                background-color 0.25s ease,
                border-color 0.25s ease,
                opacity 0.15s ease;
    mix-blend-mode: difference;
}

/* Hover over interactive elements — grow + accent ring */
.rct-cursor.is-hover {
    width: 40px;
    height: 40px;
    margin-left: -20px;
    margin-top: -20px;
    background-color: transparent;
    border: 1.5px solid var(--recterior-accent);
}

/* Click — shrink briefly */
.rct-cursor.is-click {
    width: 30px;
    height: 30px;
    margin-left: -15px;
    margin-top: -15px;
}

/* Hidden when mouse leaves the viewport */
.rct-cursor.is-hidden {
    opacity: 0 !important;
}

/* Hide custom cursor on touch devices */
@media (hover: none) and (pointer: coarse) {
    .rct-cursor {
        display: none !important;
    }
    body.rct-custom-cursor,
    body.rct-custom-cursor a,
    body.rct-custom-cursor button {
        cursor: auto !important;
    }
}

/* ==========================================================================
   Scroll Progress Indicator
   ========================================================================== */
.rct-scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
    z-index: 99990;
    background: transparent;
    pointer-events: none;
}

.rct-scroll-progress__bar {
    height: 100%;
    width: 0%;
    background: var(--recterior-accent);
    transition: none;
    will-change: width;
}

/* ==========================================================================
   @keyframes Animations
   ========================================================================== */
@keyframes rctFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes rctSlideUp {
    from {
        opacity: 0;
        transform: translate3d(0, 30px, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes rctScaleIn {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes rctSlideInLeft {
    from {
        opacity: 0;
        transform: translate3d(-30px, 0, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes rctPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

/* Hero slide counter */
.hero-slide-counter {
    position: absolute;
    bottom: 3rem;
    right: 3rem;
    z-index: 5;
    font-family: var(--recterior-font-heading);
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.5);
}

.hero-counter-current {
    color: var(--recterior-white);
    font-size: 1.5rem;
    font-weight: 700;
}

.hero-counter-sep {
    margin: 0 0.3rem;
}

/* Hero slide zoom targets (bg image / video only, not text) */
.hero-slide__bg,
.hero-slide__video-bg,
.hero-slide__youtube-bg {
    will-change: transform;
    transform-origin: center center;
}

/* Hero content initial hidden state (GSAP animates in) */
.hero-carousel .hero-subtitle,
.hero-carousel .hero-title,
.hero-carousel .hero-content .btn-underlined {
    will-change: transform, opacity;
}

/* ==========================================================================
   Text Split Animation Styles
   ========================================================================== */
[data-split-text] {
    will-change: auto;
}

.split-text-applied .split-word,
.split-text-applied .split-line {
    overflow: hidden;
    display: inline-block;
    vertical-align: top;
}

.split-text-applied .split-inner {
    display: inline-block;
    will-change: transform, opacity;
}

/* ==========================================================================
   Enhanced Hover Effects — Portfolio
   ========================================================================== */
.portfolio-item .portfolio-overlay {
    transform: translateY(20px);
    opacity: 0;
}

.portfolio-item:hover .portfolio-overlay {
    transform: translateY(0);
    opacity: 1;
}

.portfolio-item .portfolio-title {
    transform: translateY(15px);
    transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.portfolio-item:hover .portfolio-title {
    transform: translateY(0);
}

.portfolio-item .portfolio-category {
    transform: translateY(10px);
    opacity: 0;
    transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0.05s,
                opacity 0.4s ease 0.05s;
}

.portfolio-item:hover .portfolio-category {
    transform: translateY(0);
    opacity: 1;
}

/* ==========================================================================
   Enhanced Hover Effects — Showcase
   ========================================================================== */
.showcase-item .showcase-link {
    transform: translateY(20px);
    opacity: 0;
    transition: transform 0.32s cubic-bezier(0.16, 1, 0.3, 1) 0.1s,
                opacity 0.26s cubic-bezier(0.16, 1, 0.3, 1) 0.1s;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    text-decoration: none;
    font-size: var(--rct-showcase-cta-size, 0.92rem);
    color: var(--recterior-white);
}

.showcase-item .showcase-link--underlined {
    text-decoration: underline;
    text-underline-offset: 3px;
}

.showcase-item .showcase-link--solid {
    background: var(--recterior-accent, #AC8C66);
    color: var(--recterior-accent-contrast, #121B1D);
    padding: 0.5rem 0.85rem;
}

.showcase-item .showcase-link--outline {
    border: 1px solid rgba(255, 255, 255, 0.65);
    padding: 0.45rem 0.8rem;
}

.showcase-item .showcase-link--text {
    text-decoration: none;
    padding: 0;
}

.showcase-item:hover .showcase-link {
    transform: translateY(0);
    opacity: 1;
}

/* ==========================================================================
   Enhanced Hover Effects — Services
   ========================================================================== */
.services-list .service-item {
    position: relative;
    padding-left: 0;
    border-left: 3px solid transparent;
}

.services-list .service-item:hover {
    padding-left: 1rem;
    border-left-color: var(--recterior-accent);
    border-bottom-color: var(--recterior-accent);
}

.services-list .service-item:hover .service-icon {
    animation: rctPulse 0.5s ease;
}

/* ==========================================================================
   Enhanced Hover Effects — Team
   ========================================================================== */
.team-member .team-info {
    overflow: hidden;
}

.team-member .team-name {
    transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.team-member .team-role {
    transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0.05s,
                opacity 0.4s ease 0.05s;
}

/* ==========================================================================
   Horizontal Scroll Marquee
   ========================================================================== */
.scroll-marquee-wrap {
    overflow: hidden;
    white-space: nowrap;
}

.scroll-marquee {
    display: inline-block;
    white-space: nowrap;
    font-family: var(--recterior-font-heading);
    font-size: clamp(3rem, 8vw, 8rem);
    font-weight: 700;
    color: rgba(255, 255, 255, 0.03);
    -webkit-text-stroke: 1px rgba(255, 255, 255, 0.08);
    line-height: 1;
    will-change: transform;
    user-select: none;
    pointer-events: none;
}

/* ==========================================================================
   GPU acceleration helpers
   ========================================================================== */
.fade-up,
.fade-in,
.stagger-children > *,
.reveal-up,
.reveal-scale {
    will-change: transform, opacity;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.parallax-bg,
.parallax-image,
[data-parallax-speed] {
    will-change: transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

/* ==========================================================================
   Reveal-up container
   ========================================================================== */
.reveal-up-wrap {
    overflow: hidden;
    display: block;
}

/* ==========================================================================
   Menu Trigger Button (Hamburger + "Menu" text)
   ========================================================================== */
.rct-menu-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    background: none;
    border: none;
    padding: 0.5rem 0;
    cursor: pointer;
    z-index: 10000;
    position: relative;
}

.rct-menu-trigger__text {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--recterior-header-trigger-foreground);
    font-family: var(--recterior-font-body);
    transition: opacity 0.3s ease;
}

.rct-menu-trigger__bars {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 28px;
    height: 20px;
    position: relative;
}

.rct-menu-trigger__bar {
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--recterior-header-trigger-foreground);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                opacity 0.3s ease,
                width 0.3s ease;
    position: absolute;
    left: 0;
}

.rct-menu-trigger__bar:nth-child(1) {
    top: 0;
    transform-origin: center center;
}

.rct-menu-trigger__bar:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
}

.rct-menu-trigger__bar:nth-child(3) {
    bottom: 0;
    width: 60%;
    margin-left: auto;
    left: auto;
    right: 0;
    transform-origin: center center;
}

/* Active state: bars form X */
.rct-menu-trigger.is-active .rct-menu-trigger__bar:nth-child(1) {
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
}

.rct-menu-trigger.is-active .rct-menu-trigger__bar:nth-child(2) {
    opacity: 0;
    transform: translateY(-50%) scaleX(0);
}

.rct-menu-trigger.is-active .rct-menu-trigger__bar:nth-child(3) {
    bottom: auto;
    top: 50%;
    width: 100%;
    transform: translateY(-50%) rotate(-45deg);
}

/* Language Dropdown */
.rct-lang-dropdown {
    position: relative;
}

.rct-lang-dropdown__toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: transparent;
    border: 1px solid transparent;
    color: var(--recterior-header-trigger-foreground);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-family: var(--recterior-font-body);
    cursor: pointer;
    padding: 0.35rem 0.55rem;
    transition: color 0.25s ease, border-color 0.25s ease, background-color 0.25s ease;
}

.rct-lang-dropdown__toggle i {
    font-size: 0.75rem;
    opacity: 0.75;
}

.rct-lang-dropdown__toggle:hover {
    color: var(--recterior-accent);
    border-color: var(--recterior-border);
    background-color: rgba(255, 255, 255, 0.03);
}

.rct-lang-dropdown__menu {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 0.5rem;
    background-color: rgba(18, 27, 29, 0.98);
    border: 1px solid var(--recterior-border);
    padding: 0.4rem 0;
    min-width: 120px;
    list-style: none;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease;
    z-index: 100;
}

.rct-lang-dropdown.is-open .rct-lang-dropdown__menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.rct-lang-dropdown__item {
    display: block;
    padding: 0.4rem 1rem;
    color: var(--recterior-header-dropdown-text);
    font-size: 0.8rem;
    font-weight: 500;
    text-decoration: none;
    transition: color 0.2s ease, background-color 0.2s ease;
}

.rct-lang-dropdown__item:hover {
    color: var(--recterior-header-dropdown-hover-text);
    background-color: var(--recterior-header-dropdown-hover-bg);
}

.rct-lang-dropdown__item.is-active {
    color: var(--recterior-accent);
}

/* Side Drawer Trigger — Dot Grid → X (matches reference .style-3) */
.rct-drawer-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    padding: 0.5rem;
    cursor: pointer;
    position: relative;
    color: var(--recterior-header-trigger-foreground);
    transition: color 0.3s ease;
}

.rct-drawer-trigger:hover {
    color: var(--recterior-accent);
}

.recterior-navbar.scrolled .rct-menu-trigger__text,
.recterior-navbar.scrolled .rct-menu-trigger__bar,
.recterior-navbar.scrolled .rct-lang-dropdown__toggle,
.recterior-navbar.scrolled .rct-drawer-trigger,
.recterior-navbar:not(.navbar-transparent) .rct-menu-trigger__text,
.recterior-navbar:not(.navbar-transparent) .rct-menu-trigger__bar,
.recterior-navbar:not(.navbar-transparent) .rct-lang-dropdown__toggle,
.recterior-navbar:not(.navbar-transparent) .rct-drawer-trigger {
    color: var(--recterior-header-trigger-sticky-foreground);
}

.recterior-navbar.scrolled .rct-menu-trigger__bar,
.recterior-navbar:not(.navbar-transparent) .rct-menu-trigger__bar {
    background-color: var(--recterior-header-trigger-sticky-foreground);
}

.rct-drawer-trigger__bars {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 24px;
    height: 24px;
    transition: border 0.3s, background 0.3s;
}

.rct-drawer-trigger__bars .rct-drawer-trigger__bar {
    display: inline-block;
    position: relative;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background-color: currentColor;
    box-shadow: 9px 0 0 currentColor;
    margin: 3px 9px 3px 0;
    transition: all 0.3s ease;
}

.rct-drawer-trigger__bars .rct-drawer-trigger__bar:last-child {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 24px;
    height: 2px;
    border-radius: 1px;
    box-shadow: none !important;
    opacity: 0;
    transform: translate(-50%, -50%) rotate(-45deg) scale(0);
    margin: 0;
}

.rct-drawer-trigger__bars .rct-drawer-trigger__bar:last-child::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: currentColor;
    border-radius: inherit;
    transform: rotate(90deg);
}

/* Active state — dots → X cross */
.rct-drawer-trigger.is-active .rct-drawer-trigger__bars .rct-drawer-trigger__bar:nth-child(1),
.rct-drawer-trigger.is-active .rct-drawer-trigger__bars .rct-drawer-trigger__bar:nth-child(2),
.rct-drawer-trigger__bars.is-active .rct-drawer-trigger__bar:nth-child(1),
.rct-drawer-trigger__bars.is-active .rct-drawer-trigger__bar:nth-child(2) {
    opacity: 0;
}

.rct-drawer-trigger.is-active .rct-drawer-trigger__bars .rct-drawer-trigger__bar:last-child,
.rct-drawer-trigger__bars.is-active .rct-drawer-trigger__bar:last-child {
    opacity: 1;
    transform: translate(-50%, -50%) rotate(-45deg) scale(1);
}

/* ==========================================================================
   Fullscreen Menu Overlay
   ========================================================================== */
.rct-fullscreen-menu {
    position: fixed;
    inset: 0;
    z-index: 9990;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    overflow-y: auto;
    overflow-x: hidden;
    transition: visibility 0s 0.6s, opacity 0s 0.6s;
}

.rct-fullscreen-menu.is-open {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transition: visibility 0s 0s, opacity 0s 0s;
}

/* Animated background columns */
.rct-fsm__bg {
    position: fixed;
    inset: 0;
    display: flex;
    z-index: 0;
    pointer-events: none;
    opacity: 0.9;
}

.rct-fsm__bg-col {
    flex: 1;
    background-color: var(--recterior-header-sticky-light-text, #1a1a1a);
    transform: scaleY(0);
    transform-origin: top center;
    transition: none;
}

/* Inner layout */
.rct-fsm__inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    padding: 8rem 3rem 2rem;
}

/* Content: nav (left) + visual (right) */
.rct-fsm__content {
    display: flex;
    align-items: flex-start;
    flex: 1;
    gap: 3rem;
}

/* Navigation links */
.rct-fsm__nav {
    flex: 1;
    max-width: 700px;
}

.rct-fsm__nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.rct-fsm__nav-list > .nav-item {
    opacity: 0;
    transform: translateY(30px);
}

.rct-fsm__nav-list > .nav-item > .nav-link {
    display: block;
    font-family: var(--recterior-font-heading);
    font-size: clamp(var(--recterior-menu-font-size), 5vw, 3.5rem);
    font-weight: var(--recterior-menu-font-weight);
    color: var(--recterior-menu-color);
    text-transform: var(--recterior-menu-text-transform);
    letter-spacing: var(--recterior-menu-letter-spacing);
    padding: 0.32em 0;
    line-height: 1.2;
    transition: opacity 0.3s ease, color 0.3s ease;
}

.rct-fsm__nav-list > .nav-item > .nav-link .link-sup {
    font-size: 0.3em;
}

/* Fade-inactive on hover */
.rct-fsm__nav-list:hover > .nav-item > .nav-link {
    opacity: 0.3;
}

.rct-fsm__nav-list > .nav-item:hover > .nav-link {
    opacity: 1 !important;
    color: var(--recterior-accent);
}

/* Submenu inside fullscreen menu */
.rct-fsm__nav-list .dropdown-menu,
.rct-fsm__nav-list .nav-item-children {
    position: static !important;
    display: none;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0.45rem 0 0.55rem var(--recterior-menu-submenu-indent);
    margin: 0;
    min-width: auto;
    transform: none !important;
}

.rct-fsm__nav-list .nav-item.submenu-open > .dropdown-menu,
.rct-fsm__nav-list .nav-item.submenu-open > .nav-item-children {
    display: block;
}

.rct-fsm__nav-list .dropdown-menu .nav-link,
.rct-fsm__nav-list .dropdown-menu .dropdown-item,
.rct-fsm__nav-list .nav-item-children a {
    font-family: var(--recterior-font-body);
    font-size: max(0.875rem, calc(var(--recterior-menu-font-size) - 8px));
    font-weight: var(--recterior-menu-font-weight);
    color: var(--recterior-menu-color-muted);
    padding: 0.42rem 0;
    text-transform: var(--recterior-menu-text-transform);
    letter-spacing: var(--recterior-menu-letter-spacing);
    display: block;
    background: none;
    border: none;
    transition: color 0.3s ease;
}

.rct-fsm__nav-list .dropdown-menu .dropdown-menu {
    padding-left: var(--recterior-menu-submenu-indent);
    margin-top: 0.15rem;
}

.rct-fsm__nav-list .dropdown-menu .nav-link:hover,
.rct-fsm__nav-list .dropdown-menu .dropdown-item:hover,
.rct-fsm__nav-list .nav-item-children a:hover {
    color: var(--recterior-menu-color);
    background: none;
}

.rct-fsm__nav-list .dropdown-menu > .nav-item {
    margin: 0.05rem 0;
}

.rct-fsm__nav-list > .nav-item.current-menu-item > .nav-link,
.rct-fsm__nav-list > .nav-item.current-menu-parent > .nav-link,
.rct-fsm__nav-list > .nav-item.current-menu-ancestor > .nav-link,
.rct-fsm__nav-list .dropdown-menu > .nav-item.current-menu-item > .rct-menu-link,
.rct-fsm__nav-list .dropdown-menu > .nav-item.current-menu-parent > .rct-menu-link,
.rct-fsm__nav-list .dropdown-menu > .nav-item.current-menu-ancestor > .rct-menu-link {
    color: var(--recterior-menu-color-active);
    opacity: 1 !important;
}

/* Submenu expander arrow */
.rct-fsm__nav-list > .nav-item.menu-item-has-children > .nav-link::after,
.rct-fsm__nav-list > .nav-item.dropdown > .nav-link::after {
    content: '';
    display: none;
}

.rct-fsm__nav-list > .nav-item.menu-item-has-children > .nav-link {
    cursor: pointer;
}

/* Visual area */
.rct-fsm__visual {
    flex: 0 0 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0.9);
}

.rct-fsm__visual-logo {
    width: 100%;
    max-width: 280px;
    height: auto;
    opacity: 0.2;
    filter: brightness(1.2);
}

.rct-fsm__visual-logo--text {
    color: var(--recterior-white);
    font-family: var(--recterior-font-heading);
    font-size: clamp(2rem, 3vw, 3rem);
    font-weight: 600;
    letter-spacing: 1px;
    text-align: center;
}

/* Footer bar */
.rct-fsm__footer {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    padding-top: 1.5rem;
    margin-top: 2rem;
    opacity: 0;
    transform: translateY(20px);
}

.rct-fsm__footer-label {
    font-family: var(--recterior-font-body);
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--recterior-white);
    margin-bottom: 0.5rem;
}

.rct-fsm__footer-value {
    margin: 0;
    color: var(--recterior-white);
}

.rct-fsm__footer-value a {
    color: var(--recterior-white);
    font-size: 1rem;
    text-decoration: none;
    transition: color 0.25s ease;
}

.rct-fsm__footer-value a:hover {
    color: var(--recterior-accent);
}

.rct-fsm__footer-social {
    display: flex;
    align-items: flex-end;
    gap: 0.75rem;
}

.rct-fsm__social-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--recterior-white);
    font-size: 0.85rem;
    transition: var(--recterior-transition);
    text-decoration: none;
}

.rct-fsm__social-icon:hover {
    border-color: var(--recterior-white);
    color: var(--recterior-accent);
}

/* Body scroll lock */
body.rct-menu-open,
body.rct-modal-open {
    overflow: hidden !important;
}

/* Responsive fullscreen menu */
@media (max-width: 767.98px) {
    .rct-fsm__inner {
        padding: 6rem 1.5rem 1.5rem;
    }

    .rct-fsm__nav-list > .nav-item > .nav-link {
        font-size: clamp(1.75rem, 8vw, 2.5rem);
    }

    .rct-fsm__footer {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .rct-fsm__footer-social {
        justify-content: flex-start;
    }
}

/* ==========================================================================
   Side Drawer (matches reference: 400px right panel, backdrop, smooth slide)
   ========================================================================== */
.rct-side-drawer {
    position: fixed;
    inset: 0;
    z-index: 9996;
    visibility: hidden;
    pointer-events: none;
    display: flex;
    justify-content: flex-end;
}

.rct-side-drawer.is-open {
    visibility: visible;
    pointer-events: auto;
}

/* Backdrop overlay */
.rct-side-drawer__overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0);
    transition: background-color 0.6s ease;
    z-index: 0;
}

.rct-side-drawer.is-open .rct-side-drawer__overlay {
    background-color: rgba(0, 0, 0, 0.62);
}

/* Panel — slides from right */
.rct-side-drawer__panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(400px, 90vw);
    max-width: 90vw;
    height: 100vh;
    height: 100dvh;
    background-color: #111a1d;
    border-left: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 18px 52px rgba(0, 0, 0, 0.48);
    transform: translate3d(100%, 0, 0);
    opacity: 0;
    transition: transform 0.85s cubic-bezier(0.23, 1, 0.32, 1),
                opacity 0.6s step-end;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0 40px;
    display: flex;
    flex-direction: column;
    z-index: 100;
}

.rct-side-drawer.is-open .rct-side-drawer__panel {
    transform: translate3d(0, 0, 0);
    opacity: 1;
    transition: transform 0.85s cubic-bezier(0.23, 1, 0.32, 1),
                opacity 0.6s step-start;
}

/* Close button — positioned top-right inside panel */
.rct-side-drawer__close {
    position: absolute;
    top: 1.5em;
    right: 1.5em;
    z-index: 2;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    color: rgba(255, 255, 255, 0.84);
    opacity: 0;
    transition: opacity 0.3s ease 0.2s, color 0.3s ease;
}

.rct-side-drawer.is-open .rct-side-drawer__close {
    opacity: 1;
}

.rct-side-drawer__close:hover {
    color: var(--recterior-white);
}

/* Panel content */
.rct-side-drawer__content {
    flex: 1;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    padding-top: 4.75rem;
    padding-bottom: 2.5rem;
    opacity: 0;
    transform: translate3d(25%, 0, 0);
    transition: opacity 0.5s ease, transform 0.7s cubic-bezier(0.23, 1, 0.32, 1);
    transition-delay: 0s;
}

.rct-side-drawer.is-open .rct-side-drawer__content {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    transition-delay: 0.175s;
}

/* Services section — large menu links */
.rct-sd__section {
    margin-bottom: 0;
}

.rct-sd__section--services {
    margin-bottom: 0;
}

.rct-sd__heading {
    font-family: var(--recterior-font-body);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: rgba(255, 255, 255, 0.62);
    margin-bottom: 1.35rem;
    white-space: normal;
}

/* Large service menu links (reference: 35px, #717171 → white on hover) */
.rct-sd__menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.rct-sd__menu li {
    margin-bottom: 0.45rem;
}

.rct-sd__menu li a {
    color: var(--recterior-menu-color-muted);
    font-family: var(--recterior-font-heading);
    font-size: clamp(1.2rem, 2.8vw, var(--recterior-menu-font-size));
    font-weight: var(--recterior-menu-font-weight);
    line-height: 1.22;
    letter-spacing: var(--recterior-menu-letter-spacing);
    text-transform: var(--recterior-menu-text-transform);
    text-decoration: none;
    transition: color 0.3s ease;
    padding: 0.16rem 0;
}

.rct-sd__menu li a:hover {
    color: var(--recterior-menu-color);
}

.rct-sd__menu .dropdown-menu {
    position: static !important;
    transform: none !important;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0.22rem 0 0.34rem var(--recterior-menu-submenu-indent);
    margin: 0;
    min-width: auto;
    display: none;
}

.rct-sd__menu .submenu-open > .dropdown-menu {
    display: block;
}

.rct-sd__menu .dropdown-menu .rct-menu-link {
    font-family: var(--recterior-font-body);
    font-size: max(0.875rem, calc(var(--recterior-menu-font-size) - 8px));
    line-height: 1.4;
    color: var(--recterior-menu-color-muted);
    padding: 0.34rem 5px;
}

.rct-sd__menu .dropdown-menu .dropdown-menu {
    padding-left: var(--recterior-menu-submenu-indent);
}

.rct-sd__menu > .nav-item.current-menu-item > .rct-menu-link,
.rct-sd__menu > .nav-item.current-menu-parent > .rct-menu-link,
.rct-sd__menu > .nav-item.current-menu-ancestor > .rct-menu-link,
.rct-sd__menu .dropdown-menu > .nav-item.current-menu-item > .rct-menu-link,
.rct-sd__menu .dropdown-menu > .nav-item.current-menu-parent > .rct-menu-link,
.rct-sd__menu .dropdown-menu > .nav-item.current-menu-ancestor > .rct-menu-link {
    color: var(--recterior-menu-color-active);
}

/* Spacer between services and info sections (reference: 25vh) */
.rct-sd__spacer {
    flex: 1 1 auto;
    min-height: clamp(1rem, 4vh, 2.5rem);
}

/* Info grid — auto-fit columns by available drawer width, pinned to bottom */
.rct-sd__info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1.1rem 1.25rem;
    margin-top: auto;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    align-items: start;
}

.rct-sd__info-col .rct-sd__section {
    margin-bottom: 0;
}

/* Regular list (Social, etc.) */
.rct-sd__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.rct-sd__list li {
    margin-bottom: 0.35rem;
}

.rct-sd__list li a {
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.9rem;
    line-height: 1.55;
    letter-spacing: 0.1px;
    text-decoration: none;
    transition: color 0.3s ease;
}

.rct-sd__list li a:hover {
    color: var(--recterior-accent);
}

/* Info text */
.rct-sd__text {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.88rem;
    line-height: 1.55;
    margin-bottom: 0.3rem;
    white-space: normal;
}


/* ==========================================================================
   Focus Visible — Keyboard Accessibility
   ========================================================================== */
.btn-accent:focus-visible,
.btn-outline-accent:focus-visible,
.btn-underlined:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(172, 140, 102, 0.25);
}

.filter-btn:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 2px;
}

.scroll-to-top:focus-visible {
    outline: 2px solid var(--recterior-white);
    outline-offset: 2px;
}

.recterior-navbar .nav-link:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: -2px;
    border-radius: 2px;
}

.social-icon:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 2px;
    border-radius: 2px;
}

.dropdown-item:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: -2px;
}

.rct-menu-trigger:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 4px;
    border-radius: 2px;
}

.rct-drawer-trigger:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 4px;
    border-radius: 2px;
}

.rct-side-drawer__close:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 4px;
    border-radius: 4px;
    background-color: rgba(172, 140, 102, 0.12);
}

.rct-fsm__nav-list > .nav-item > .nav-link:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 2px;
}

.rct-fsm__social-icon:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 2px;
}

.rct-sd__list li a:focus-visible,
.rct-sd__menu li a:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 2px;
    border-radius: 2px;
}

.rct-lang-dropdown__toggle:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: 4px;
    border-radius: 2px;
}

.rct-lang-dropdown__item:focus-visible {
    outline: 2px solid var(--recterior-accent);
    outline-offset: -2px;
}

/* ==========================================================================
   Side Drawer Responsive
   ========================================================================== */
@media (max-width: 767px) {
    .rct-sd__menu li a {
        font-size: 1.5rem;
    }

    .rct-sd__spacer {
        min-height: 0.9rem;
    }

    .rct-sd__info-grid {
        gap: 1rem;
        padding-top: 1.15rem;
    }

    .rct-side-drawer__panel {
        padding: 0 24px;
    }

    .rct-side-drawer__content {
        padding-top: 4.25rem;
        padding-bottom: 2rem;
    }
}

/* ==========================================================================
   WordPress Admin Bar Compatibility
   ========================================================================== */
.admin-bar .recterior-navbar {
    top: 32px;
}

.admin-bar .rct-scroll-progress {
    top: 32px;
}

.admin-bar .rct-fullscreen-menu {
    top: 32px;
}

.admin-bar .rct-fsm__bg {
    top: 32px;
}

.admin-bar .rct-fsm__inner {
    padding-top: calc(8rem + 32px);
}

.admin-bar .rct-side-drawer {
    top: 32px;
}

.admin-bar .rct-side-drawer__panel {
    height: calc(100dvh - 32px);
}

@media (max-width: 782px) {
    .admin-bar .recterior-navbar {
        top: 46px;
    }

    .admin-bar .rct-scroll-progress {
        top: 46px;
    }

    .admin-bar .rct-fullscreen-menu {
        top: 46px;
    }

    .admin-bar .rct-fsm__bg {
        top: 46px;
    }

    .admin-bar .rct-fsm__inner {
        padding-top: calc(6rem + 46px);
    }

    .admin-bar .rct-side-drawer {
        top: 46px;
    }

    .admin-bar .rct-side-drawer__panel {
        height: calc(100dvh - 46px);
    }
}

@media (max-width: 600px) {
    .admin-bar .recterior-navbar {
        top: 0;
    }

    .admin-bar .rct-scroll-progress {
        top: 0;
    }

    .admin-bar .rct-fullscreen-menu {
        top: 0;
    }

    .admin-bar .rct-fsm__bg {
        top: 0;
    }

    .admin-bar .rct-side-drawer {
        top: 0;
    }

    .admin-bar .rct-side-drawer__panel {
        height: 100dvh;
    }
}

/* ==========================================================================
   Mobile Header
   ========================================================================== */
.rct-mobile-header {
    display: none;
}

@media (max-width: 1199.98px) {
    /* Hide desktop header/navbar on tablet and mobile to prevent duplicate logos. */
    .site-header.main-header {
        display: none;
    }

    #rct-site-content {
        padding-top: 60px;
    }

    .rct-mobile-header {
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        z-index: 1040;
        background: var(--recterior-bg);
    }

    .rct-mobile-header__inner {
        height: 60px;
        padding: 0 16px;
        justify-content: space-between;
    }

    .rct-mobile-toggle {
        background: none;
        border: none;
        padding: 8px;
        cursor: pointer;
        z-index: 1050;
    }

    .rct-mobile-toggle__bars {
        display: flex;
        flex-direction: column;
        gap: 5px;
        width: 24px;
    }

    .rct-mobile-toggle__bars .bar {
        display: block;
        width: 100%;
        height: 2px;
        background: var(--recterior-white);
        transition: var(--recterior-transition);
    }

    .rct-mobile-toggle__bars.is-active .bar:nth-child(1) {
        transform: rotate(45deg) translate(5px, 5px);
    }

    .rct-mobile-toggle__bars.is-active .bar:nth-child(2) {
        opacity: 0;
    }

    .rct-mobile-toggle__bars.is-active .bar:nth-child(3) {
        transform: rotate(-45deg) translate(5px, -5px);
    }

    .rct-mobile-header__logo {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }

    .rct-mobile-header__logo img {
        max-height: 32px;
        width: auto;
    }

    .rct-mobile-nav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        height: 100dvh;
        background: var(--recterior-bg);
        z-index: 1045;
        transform: translateY(-100%);
        transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
        overflow-y: auto;
        padding: 80px 20px 40px;
    }

    .rct-mobile-nav.is-open {
        transform: translateY(0);
    }

    .rct-mobile-nav__close {
        position: absolute;
        top: 16px;
        right: 16px;
        background: none;
        border: none;
        cursor: pointer;
        padding: 8px;
    }

    .rct-mobile-nav__list {
        list-style: none;
        padding: 0;
        margin: 0;
    }

    .rct-mobile-nav__list > .nav-item {
        border-bottom: 1px solid var(--recterior-border);
    }

    .rct-mobile-nav__list > .nav-item > .nav-link {
        display: block;
        padding: 17px 0;
        font-family: var(--recterior-font-heading);
        font-size: var(--recterior-menu-font-size);
        font-weight: var(--recterior-menu-font-weight);
        letter-spacing: var(--recterior-menu-letter-spacing);
        text-transform: var(--recterior-menu-text-transform);
        color: var(--recterior-menu-color);
        text-decoration: none;
    }

    .rct-mobile-nav__list .link-sup {
        font-size: 10px;
        color: var(--recterior-accent);
        margin-left: 4px;
        vertical-align: super;
    }

    .rct-mobile-nav__list .dropdown-menu {
        position: static !important;
        transform: none !important;
        background: transparent;
        border: none;
        padding: 0 0 12px var(--recterior-menu-submenu-indent);
        display: none;
    }

    .rct-mobile-nav__list .submenu-open > .dropdown-menu {
        display: block;
    }

    .rct-mobile-nav__list .dropdown-menu .rct-menu-link {
        font-family: var(--recterior-font-body);
        font-size: max(0.9rem, calc(var(--recterior-menu-font-size) - 8px));
        font-weight: var(--recterior-menu-font-weight);
        letter-spacing: var(--recterior-menu-letter-spacing);
        text-transform: var(--recterior-menu-text-transform);
        padding: 0.42rem 0;
        color: var(--recterior-menu-color-muted);
    }

    .rct-mobile-nav__list .dropdown-menu .dropdown-menu {
        padding-left: var(--recterior-menu-submenu-indent);
        padding-top: 0.2rem;
    }

    .rct-mobile-nav__list > .nav-item.current-menu-item > .rct-menu-link,
    .rct-mobile-nav__list > .nav-item.current-menu-parent > .rct-menu-link,
    .rct-mobile-nav__list > .nav-item.current-menu-ancestor > .rct-menu-link,
    .rct-mobile-nav__list .dropdown-menu > .nav-item.current-menu-item > .rct-menu-link,
    .rct-mobile-nav__list .dropdown-menu > .nav-item.current-menu-parent > .rct-menu-link,
    .rct-mobile-nav__list .dropdown-menu > .nav-item.current-menu-ancestor > .rct-menu-link {
        color: var(--recterior-menu-color-active);
    }

    .admin-bar .rct-mobile-header {
        top: 32px;
    }

    .admin-bar .rct-mobile-nav {
        top: 32px;
        height: calc(100dvh - 32px);
    }

    .admin-bar #rct-site-content {
        padding-top: calc(60px + 32px);
    }
}

@media (max-width: 782px) {
    .admin-bar .rct-mobile-header {
        top: 46px;
    }

    .admin-bar .rct-mobile-nav {
        top: 46px;
        height: calc(100dvh - 46px);
    }

    .admin-bar #rct-site-content {
        padding-top: calc(60px + 46px);
    }
}

@media (max-width: 600px) {
    .admin-bar .rct-mobile-header {
        top: 0;
    }

    .admin-bar .rct-mobile-nav {
        top: 0;
        height: 100dvh;
    }

    .admin-bar #rct-site-content {
        padding-top: 60px;
    }
}


/* No gutter on row - rct-modal-form uses flush columns for bordered table-like layout */
.rct-modal-form__row.row {
    --bs-gutter-x: 0;
    --bs-gutter-y: 0;
}

.rct-modal-form__cell {
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-bottom: none;
    padding: 20px 10px 15px 20px;
}

@media (min-width: 768px) {
    .rct-modal-form__cell:nth-child(even) {
        border-left: none;
    }
}

.rct-modal-form__cell--full {
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
}

.rct-modal-form__label {
    margin: 0;
    color: rgba(255, 255, 255, 0.3);
    font-size: 14px;
}

.rct-modal-form input:not([type="checkbox"]),
.rct-modal-form textarea,
.rct-modal-form select {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px solid transparent;
    color: var(--recterior-white);
    padding: 8px 0;
    font-size: 18px;
    font-family: var(--recterior-font-body);
    outline: none;
    transition: border-color 0.3s ease;
}

.rct-modal-form input:focus,
.rct-modal-form textarea:focus,
.rct-modal-form select:focus {
    border-bottom-color: var(--recterior-accent);
}

.rct-modal-form select {
    appearance: none;
    cursor: pointer;
}

.rct-modal-form select option {
    background: var(--recterior-bg);
    color: var(--recterior-text);
}

.rct-modal-form__consent {
    padding: 1.75rem 0;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.5);
}

.rct-modal-form__consent label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.rct-modal-form__submit {
    padding: 0;
}

.rct-modal-form__submit .btn-accent {
    border: none;
    padding: 18px;
    font-size: 16px;
    letter-spacing: 1px;
    width: 100%;
    justify-content: center;
}

.rct-modal-form__submit .btn-accent:hover {
    background-color: var(--recterior-white);
    border-color: var(--recterior-white);
    color: var(--recterior-bg);
}

@media (max-width: 767px) {
    .rct-modal-form__cell {
        border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
    }

    .rct-modal-form__cell:nth-child(even) {
        border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
    }
}

/* Contact form block only: enforce consistent field borders in all layouts */
.contact-form-section .rct-modal-form__row.row {
    --bs-gutter-x: 1rem;
    --bs-gutter-y: 1rem;
}

.contact-form-section .rct-modal-form__row:not(.row) {
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 1rem;
}

.contact-form-section .rct-modal-form__cell,
.contact-form-section .rct-modal-form__cell:nth-child(even),
.contact-form-section .rct-modal-form__cell--full {
    border: none !important;
    padding: 0;
}

.contact-form-section .rct-modal-form__label {
    display: block;
    margin: 0 0 0.45rem;
}

.contact-form-section .rct-modal-form input:not([type="checkbox"]),
.contact-form-section .rct-modal-form textarea,
.contact-form-section .rct-modal-form select {
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.02);
    padding: 0.78rem 0.9rem;
    font-size: 0.98rem;
    line-height: 1.35;
}

.contact-form-section .rct-modal-form textarea {
    min-height: 140px;
    resize: vertical;
}

.contact-form-section .rct-modal-form__consent {
    margin-top: 0.25rem;
    padding: 0.35rem 0 0.15rem;
}

.contact-form-section .rct-modal-form__submit {
    margin-top: 0.35rem;
}

.contact-form-section .rct-modal-form input:not([type="checkbox"]):focus,
.contact-form-section .rct-modal-form textarea:focus,
.contact-form-section .rct-modal-form select:focus {
    border-color: var(--recterior-accent);
    box-shadow: 0 0 0 2px rgba(172, 140, 102, 0.2);
}

/* ==========================================================================
   Footer Text Rotator
   ========================================================================== */
.txt-rotate-wrap {
    display: inline-block;
    position: relative;
    vertical-align: bottom;
}

.txt-rotate-keyword {
    display: inline-block;
    opacity: 0;
    transform: translateY(100%);
    transition: opacity 0.5s ease, transform 0.5s ease;
    position: absolute;
    left: 0;
    white-space: nowrap;
}

.txt-rotate-keyword.active {
    opacity: 1;
    transform: translateY(0);
    position: relative;
}

.txt-rotate-keyword.leaving {
    opacity: 0;
    transform: translateY(-100%);
}


.footer-cta {
    position: relative;
    background-repeat: no-repeat;
    background-position: 106% 170%;
    background-size: auto;
}

/* ==========================================================================
   Services Flip Cards
   ========================================================================== */
.flip-card {
    perspective: 1000px;
    cursor: pointer;
    height: calc(var(--flip-card-height, 24rem) * var(--flip-card-height-scale, 1));
    outline: none;
}

.services-flip-section.services-flip-section--page-width > .container {
    padding-left: 0;
    padding-right: 0;
}

.flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    transition: transform var(--rct-flip-duration, 600ms) cubic-bezier(0.16, 1, 0.3, 1);
}

.flip-card.flipped .flip-card-inner {
    transform: rotateY(180deg);
}

.flip-card-front,
.flip-card-back {
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    border-radius: 0.5rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 2rem 1.5rem;
}

/* --- Front Face --- */
.flip-card-front {
    background-color: var(--rct-flip-front-bg, var(--recterior-bg-card, #1e2d30));
    border: 1px solid var(--recterior-border, rgba(255, 255, 255, 0.1));
    background-size: cover;
    background-position: center;
    transition: border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.flip-card:hover:not(.flipped) .flip-card-front {
    border-color: var(--recterior-accent, #AC8C66);
}

.flip-card:focus-visible .flip-card-front {
    border-color: var(--recterior-accent, #AC8C66);
    box-shadow: 0 0 0 2px var(--recterior-accent, #AC8C66);
}

.flip-card.flipped:focus-visible .flip-card-back {
    box-shadow: 0 0 0 2px var(--recterior-accent, #AC8C66);
}

.flip-card-front.has-bg-image {
    background-color: transparent;
}

.flip-card-front__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(18, 27, 29, calc(var(--rct-flip-front-overlay-opacity, 0.65) * 0.4)) 0%,
        rgba(18, 27, 29, var(--rct-flip-front-overlay-opacity, 0.65)) 100%
    );
    z-index: 1;
    pointer-events: none;
}

.flip-card-front__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: var(--rct-flip-front-content-justify, flex-end);
    gap: 0.75rem;
    min-height: 100%;
    padding-top: var(--rct-flip-front-content-offset-top, 0);
}

.flip-card-front__icon {
    width: 2.5rem;
    height: auto;
    filter: brightness(0) invert(1);
    opacity: 0.9;
    margin-bottom: 0.5rem;
}

.flip-card-front__title {
    font-family: var(--recterior-font-heading);
    color: var(--recterior-heading-color, #ffffff);
    font-size: var(--rct-heading-size, 1.35rem);
    font-weight: var(--rct-heading-weight, 600);
    line-height: 1.3;
    margin: 0;
    text-transform: var(--rct-flip-text-transform, none);
    letter-spacing: 0.5px;
}

.flip-card-front__desc {
    margin: 0.5rem 0 0;
    color: var(--recterior-text, #c5c5c5);
    font-size: var(--rct-text-size, 0.95rem);
    line-height: 1.6;
    text-transform: var(--rct-flip-text-transform, none);
}

.flip-card-front__arrow {
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 2;
}

/* --- Back Face --- */
.flip-card-back {
    transform: rotateY(180deg);
    background-color: var(--rct-flip-back-bg, var(--recterior-bg-light, #1a2628));
    border-left: 3px solid var(--recterior-accent, #AC8C66);
    border-top: 1px solid var(--recterior-border, rgba(255, 255, 255, 0.1));
    border-right: 1px solid var(--recterior-border, rgba(255, 255, 255, 0.1));
    border-bottom: 1px solid var(--recterior-border, rgba(255, 255, 255, 0.1));
    transition: box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.flip-card-back__content {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    justify-content: var(--rct-flip-back-content-justify, flex-start);
    padding-top: var(--rct-flip-back-content-offset-top, 0);
    scrollbar-width: thin;
    scrollbar-color: var(--recterior-accent, #AC8C66) transparent;
}

.flip-card-back__content::-webkit-scrollbar {
    width: 3px;
}

.flip-card-back__content::-webkit-scrollbar-thumb {
    background-color: var(--recterior-accent, #AC8C66);
    border-radius: 3px;
}

.flip-card-back__index {
    font-family: var(--recterior-font-heading);
    font-size: 2rem;
    font-weight: 300;
    color: var(--recterior-accent, #AC8C66);
    letter-spacing: 0.5px;
    margin-bottom: 1.5rem;
}

.flip-card-back__desc {
    color: var(--recterior-text, #c5c5c5);
    font-size: var(--rct-text-size, 0.95rem);
    line-height: 1.7;
    text-transform: var(--rct-flip-text-transform, none);
    letter-spacing: 0.3px;
}

.flip-card-back__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-shrink: 0;
    padding-top: 1rem;
}

.flip-card-back__btn {
    flex-shrink: 0;
}

.flip-card-back__btn.btn-accent {
    padding: 0.5rem 1.25rem;
    font-size: 0.7rem;
}

.flip-card-back__btn.btn-accent:hover {
    background-color: var(--recterior-white);
    border-color: var(--recterior-white);
    color: var(--recterior-bg, #121B1D);
}

/* --- Shared Arrow Button --- */
.flip-card-arrow-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.08);
    color: var(--recterior-white, #ffffff);
    font-size: 0.8rem;
    transition: background-color 0.3s ease, color 0.3s ease;
    flex-shrink: 0;
}

.flip-card-arrow-btn:hover {
    background-color: var(--recterior-accent, #AC8C66);
    color: var(--recterior-accent-contrast, #121B1D);
}

.flip-card-back__arrow {
    margin-left: auto;
}

.services-flip-section .text-accent {
    color: var(--recterior-accent, #AC8C66);
}

.services-flip-section.flip-trigger-hover .flip-card {
    cursor: pointer;
}

.services-flip-section.flip-trigger-hover .flip-card:hover .flip-card-inner,
.services-flip-section.flip-trigger-hover .flip-card:focus-within .flip-card-inner {
    transform: rotateY(180deg);
}

.services-flip-section.flip-card-cta--outline .flip-card-back__btn {
    border-color: var(--recterior-accent, #AC8C66);
    color: var(--recterior-accent, #AC8C66);
}

.services-flip-section.flip-card-cta--outline .flip-card-back__btn:hover {
    background: var(--recterior-accent, #AC8C66);
    color: var(--recterior-bg, #121B1D);
}

.services-flip-section.flip-card-cta--underlined .flip-card-back__btn {
    background: transparent !important;
    border: none !important;
    color: var(--recterior-accent, #AC8C66) !important;
    padding: 0 !important;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.services-flip-section.flip-card-cta-size--md .flip-card-back__btn {
    padding: 0.65rem 1.5rem;
    font-size: 0.85rem;
}

.services-flip-section.flip-front-glass-enabled .flip-card-front.has-bg-image .flip-card-front__content {
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 12px;
    padding-left: 0.9rem;
    padding-right: 0.9rem;
    padding-bottom: 0.9rem;
    background: rgba(255, 255, 255, var(--rct-flip-front-glass-opacity, 0.18));
    -webkit-backdrop-filter: blur(var(--rct-flip-front-glass-blur, 12px));
    backdrop-filter: blur(var(--rct-flip-front-glass-blur, 12px));
}

/* --- Responsive --- */
@media (max-width: 991.98px) {
    .flip-card {
        --flip-card-height-scale: 0.92;
    }

    .flip-card-front,
    .flip-card-back {
        padding: 1.75rem 1.25rem;
    }

    .flip-card-front__title {
        font-size: 1.2rem;
    }
}

@media (max-width: 767.98px) {
    .flip-card {
        --flip-card-height-scale: 0.85;
    }

    .flip-card-front,
    .flip-card-back {
        padding: 1.5rem 1.25rem;
    }

    .flip-card-front__title {
        font-size: 1.1rem;
    }

    .flip-card-back__index {
        font-size: 1.5rem;
        margin-bottom: 1rem;
    }

    .flip-card-back__desc {
        font-size: 0.875rem;
    }

    .flip-card-back__footer {
        padding-top: 0.75rem;
    }
}

@media (max-width: 575.98px) {
    .flip-card-front__arrow {
        bottom: 1rem;
        right: 1rem;
    }

    .flip-card-front,
    .flip-card-back {
        padding: 1.25rem 1rem;
    }

    .flip-card-back__desc {
        font-size: 0.8125rem;
        line-height: 1.6;
    }

    .flip-card-arrow-btn {
        width: 2.25rem;
        height: 2.25rem;
        font-size: 0.75rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .flip-card-inner {
        transition-duration: 1ms;
    }
}

/* ==========================================================================
   Simple Content Columns
   ========================================================================== */
.simple-content-columns {
    position: relative;
}

.simple-content-columns .scc-heading {
    margin: 0 0 clamp(1.25rem, 2.2vw, 2rem);
    color: var(--recterior-heading-color, #ffffff);
    font-size: var(--rct-heading-size, clamp(1.8rem, 3vw, 2.6rem));
    font-weight: var(--rct-heading-weight, 600);
    line-height: 1.2;
}

.simple-content-columns .scc-grid {
    display: grid;
    gap: var(--rct-scc-gap, 24px);
    grid-template-columns: repeat(var(--rct-scc-cols, 3), minmax(0, 1fr));
}

.simple-content-columns .scc-card {
    position: relative;
    overflow: hidden;
    border-radius: var(--rct-scc-card-radius, 0px);
    min-height: var(--rct-scc-item-min-h, auto);
    display: flex;
    background-color: var(--rct-scc-card-bg, var(--recterior-bg-card, #1e2d30));
    background-image: var(--rct-scc-card-image, none);
    background-position: center;
    background-size: cover;
    border: var(--rct-scc-card-border-w, 1px) solid var(--rct-scc-card-border-color, var(--rct-scc-border-color, var(--recterior-border, rgba(255, 255, 255, 0.1))));
}

.simple-content-columns .scc-card.has-bg-image::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    background: linear-gradient(
        180deg,
        rgba(18, 27, 29, 0.35) 0%,
        rgba(18, 27, 29, 0.78) 100%
    );
}

.simple-content-columns .scc-card__content {
    position: relative;
    z-index: 2;
    width: 100%;
    padding: clamp(1.2rem, 1.8vw, 1.75rem);
    display: flex;
    flex-direction: column;
    justify-content: var(--rct-scc-content-justify, flex-end);
    gap: 0.65rem;
}

.simple-content-columns .scc-card.scc-card--glass .scc-card__content {
    margin: 1rem;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, var(--rct-scc-card-glass-opacity, 0.18));
    -webkit-backdrop-filter: blur(var(--rct-scc-card-glass-blur, 12px));
    backdrop-filter: blur(var(--rct-scc-card-glass-blur, 12px));
    padding: 1rem;
}

.simple-content-columns .scc-card__subtitle {
    margin: 0;
    color: var(--recterior-accent, #AC8C66);
    font-size: var(--rct-scc-subtitle-size, 0.8rem);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.simple-content-columns .scc-card__title {
    margin: 0;
    width: 100%;
    color: var(--recterior-heading-color, #ffffff);
    font-size: var(--rct-scc-title-size, 1.35rem);
    font-weight: var(--rct-scc-title-weight, var(--rct-heading-weight, 600));
    line-height: 1.3;
    text-transform: var(--rct-scc-title-transform, none);
    text-align: var(--rct-scc-title-align, left);
}

.simple-content-columns .scc-card__desc,
.simple-content-columns .scc-card__desc p {
    margin: 0;
    color: var(--rct-scc-desc-color, var(--recterior-text-muted, #9d9d9d));
    font-size: var(--rct-scc-desc-size, var(--rct-text-size, 0.95rem));
    line-height: 1.65;
}

.simple-content-columns .scc-card__cta {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--recterior-accent, #AC8C66);
    text-decoration: none;
    font-weight: 500;
    font-size: var(--rct-scc-cta-size, 0.92rem);
}

.simple-content-columns .scc-card__cta:hover {
    color: var(--recterior-white, #ffffff);
}

@media (max-width: 991.98px) {
    .simple-content-columns .scc-grid {
        grid-template-columns: repeat(var(--rct-scc-cols-tablet, 2), minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .simple-content-columns .scc-grid {
        grid-template-columns: repeat(var(--rct-scc-cols-mobile, 1), minmax(0, 1fr));
    }

    .simple-content-columns .scc-card__content {
        padding: 1.25rem;
    }
}

/* ==========================================================================
   Numbered Services Block
   ========================================================================== */
.numbered-services {
    position: relative;
    padding: var(--rct-ns-pad-top, 150px) 0 var(--rct-ns-pad-bottom, 100px);
}

.numbered-services__section-head {
    margin-bottom: clamp(1.5rem, 2.5vw, 2.5rem);
}

.numbered-services__section-title {
    margin: 0 0 0.75rem;
    color: var(--rct-ns-section-title-color, var(--recterior-heading-color, #fff));
    font-size: var(--rct-ns-section-title-size, clamp(1.75rem, 3vw, 2.25rem));
    line-height: var(--rct-ns-section-title-line-height, 1.2);
    font-weight: var(--rct-ns-section-title-weight, 600);
}

.numbered-services__section-desc {
    margin: 0;
    color: var(--rct-ns-section-desc-color, var(--recterior-text, var(--recterior-text-muted, #8a9a9c)));
    font-size: var(--rct-ns-section-desc-size, 1.125rem);
    line-height: var(--rct-ns-section-desc-line-height, 1.6);
    font-weight: var(--rct-ns-section-desc-weight, 400);
    max-width: 72ch;
}

.numbered-services__section-head--center {
    text-align: center;
}

.numbered-services__section-head--center .numbered-services__section-desc {
    margin-left: auto;
    margin-right: auto;
}

.numbered-services__section-head--right {
    text-align: right;
}

.numbered-services__section-head--right .numbered-services__section-desc {
    margin-left: auto;
}

.numbered-services__card {
    position: relative;
    padding-right: var(--rct-ns-card-pad-right, 16px);
    min-height: var(--rct-ns-card-min-height, auto);
    padding-left: var(--rct-ns-card-pad-x, 0px);
    padding-top: var(--rct-ns-card-pad-y, 0px);
    padding-bottom: var(--rct-ns-card-pad-y, 0px);
    background-color: var(--rct-ns-card-bg, transparent);
    border: var(--rct-ns-card-bw, 1px) solid var(--rct-ns-card-bc, transparent);
    border-radius: var(--rct-ns-card-radius, 0px);
    overflow: visible;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.numbered-services .row > [class*="col-"] {
    display: flex;
}

.numbered-services__card {
    width: 100%;
}

.numbered-services__card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    border-radius: inherit;
}

.numbered-services__card::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 2px;
    background: var(--rct-ns-card-hover-accent, transparent);
    opacity: 0;
    transform: scaleX(0.4);
    transform-origin: left center;
    transition: opacity 0.3s ease, transform 0.3s ease;
    z-index: 2;
}

.numbered-services--hover-lift .numbered-services__card:hover {
    transform: translateY(calc(var(--rct-ns-card-hover-lift-y, 8px) * -1));
}

.numbered-services__card:hover::after {
    opacity: 1;
    transform: scaleX(1);
}

.numbered-services--card-flat .numbered-services__card {
    border-color: transparent;
}

.numbered-services--card-outlined .numbered-services__card {
    background-color: transparent;
}

.numbered-services--card-glass .numbered-services__card {
    background-color: rgba(255, 255, 255, var(--rct-ns-card-glass-opacity, 0.08));
    backdrop-filter: blur(var(--rct-ns-card-glass-blur, 12px));
    -webkit-backdrop-filter: blur(var(--rct-ns-card-glass-blur, 12px));
    border-color: var(--rct-ns-card-bc, rgba(255, 255, 255, 0.2));
    min-height: max(var(--rct-ns-card-min-height, 0px), 220px);
    padding-top: max(var(--rct-ns-card-pad-y, 0px), 18px);
    padding-bottom: max(var(--rct-ns-card-pad-y, 0px), 18px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.numbered-services--card-glass .numbered-services__title,
.numbered-services--card-glass .numbered-services__desc {
    width: 100%;
}

.numbered-services__number {
    position: absolute;
    top: var(--rct-ns-number-top, -121px);
    right: var(--rct-ns-number-right, 0px);
    font-family: var(--recterior-font-heading, 'Inter', sans-serif);
    font-size: var(--rct-ns-number-size, 120px) !important;
    font-weight: 900;
    line-height: 1em;
    letter-spacing: -1px;
    color: transparent;
    -webkit-text-stroke: var(--rct-ns-number-stroke-width, 2px) var(--rct-ns-number-stroke, #707070);
    writing-mode: vertical-rl;
    text-orientation: mixed;
    text-align: right;
    pointer-events: none;
    user-select: none;
    transition: -webkit-text-stroke-color 0.3s ease;
    z-index: 1;
}

.numbered-services__card:hover .numbered-services__number {
    -webkit-text-stroke-color: var(--rct-ns-number-stroke-hover, #fff);
}

.numbered-services--num-horizontal .numbered-services__number {
    writing-mode: horizontal-tb;
    text-orientation: initial;
}

.numbered-services__title {
    font-family: var(--recterior-font-heading, 'Inter', sans-serif);
    font-size: var(--rct-ns-title-size, 16px) !important;
    line-height: var(--rct-ns-title-line, 44px) !important;
    color: var(--recterior-heading-color, var(--recterior-text, #fff)) !important;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
}

.numbered-services__desc {
    font-size: var(--rct-ns-desc-size, 18px) !important;
    line-height: var(--rct-ns-desc-line, 22px) !important;
    color: var(--recterior-text, var(--recterior-text-muted, #8a9a9c)) !important;
    margin: 0 var(--rct-ns-desc-margin-right, 32px) 0.5em 0;
    position: relative;
    z-index: 1;
}

.numbered-services--align-center .numbered-services__title,
.numbered-services--align-center .numbered-services__desc {
    text-align: center;
}

.numbered-services__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.numbered-services--align-center .numbered-services__cta {
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 1024px) {
    .numbered-services {
        padding-top: calc(var(--rct-ns-pad-top, 150px) * 0.6);
        padding-bottom: calc(var(--rct-ns-pad-bottom, 100px) * 0.7);
        padding-left: 40px;
        padding-right: 40px;
    }

    .numbered-services__number {
        top: calc(var(--rct-ns-number-top, -121px) * 0.9);
    }
}

@media (max-width: 991.98px) {
    .numbered-services--no-stagger-mobile .numbered-services__card { margin-top: 0 !important; }
    .numbered-services--stagger-mobile .numbered-services__card { margin-top: calc(var(--rct-ns-offset, 0px) * 0.55) !important; }
    .numbered-services__card { margin-bottom: 3rem; }

    .numbered-services__number {
        font-size: calc(var(--rct-ns-number-size, 120px) * 0.67);
        top: calc(var(--rct-ns-number-top, -121px) * 0.82);
    }
}

@media (max-width: 767.98px) {
    .numbered-services {
        padding-top: calc(var(--rct-ns-pad-top, 150px) * 0.45);
        padding-bottom: calc(var(--rct-ns-pad-bottom, 100px) * 0.45);
        padding-left: 20px;
        padding-right: 20px;
    }

    .numbered-services--stagger-mobile .numbered-services__card { margin-top: calc(var(--rct-ns-offset, 0px) * 0.45) !important; }
    .numbered-services--no-stagger-mobile .numbered-services__card { margin-top: 0 !important; }
    .numbered-services__card { padding-right: calc(var(--rct-ns-card-pad-right, 16px) * 0.5); }

    .numbered-services__number {
        font-size: calc(var(--rct-ns-number-size, 120px) * 0.6);
        top: calc(var(--rct-ns-number-top, -121px) * 0.8);
    }

    .numbered-services__desc { margin-right: calc(var(--rct-ns-desc-margin-right, 32px) * 0.45); }
}

/* ==========================================================================
   Flickity Slideshow Block
   ========================================================================== */
.flickity-slideshow {
    position: relative;
    overflow: visible;
    width: 100%;
    min-height: 320px;
    --rct-flickity-slides-per-view: 4;
    --rct-flickity-slide-height: 150%;
    --rct-flickity-arrow-offset: clamp(0.75rem, 2vw, 1.5rem);
    --rct-flickity-bg-overlay: rgba(0, 0, 0, 0.26);
    --rct-flickity-grad-start: rgba(0, 0, 0, 0.64);
    --rct-flickity-grad-mid: rgba(0, 0, 0, 0.18);
    --rct-flickity-grad-end: rgba(0, 0, 0, 0.64);
    --rct-flickity-content-pad-top: 1.55rem;
    --rct-flickity-content-pad-bottom: 1.55rem;
    --rct-flickity-content-pad-x: 1.25rem;
    --rct-flickity-content-gap: 0.55rem;
    --rct-flickity-content-max-width: 34ch;
    --rct-flickity-dots-gap: 0.8rem;
    --rct-flickity-dots-box-height: 1.95rem;
    --rct-flickity-arrow-size: 46px;
    --rct-flickity-glass-color: transparent;
    --rct-flickity-glass-opacity: 0.28;
    padding-bottom: 0;
}

.flickity-slideshow.has-dots {
    padding-bottom: calc(var(--rct-flickity-dots-gap) + var(--rct-flickity-dots-box-height));
}

.flickity-slideshow__inner {
    position: relative;
    width: 100%;
}

.flickity-slideshow__header {
    margin-bottom: 0.95rem;
}

.flickity-slideshow__block-title {
    margin: 0;
    color: var(--recterior-heading-color, #fff);
    font-size: var(--rct-flickity-header-title-size, clamp(1.2rem, 2vw, 1.65rem));
    font-weight: var(--rct-flickity-header-title-weight, 600);
    line-height: 1.25;
}

.flickity-slideshow__block-desc {
    margin: 0.4rem 0 0;
    color: var(--recterior-text, rgba(255, 255, 255, 0.82));
    font-size: var(--rct-flickity-header-desc-size, 1rem);
    font-weight: var(--rct-flickity-header-desc-weight, 400);
    max-width: 68ch;
}

.flickity-slideshow.is-header-left .flickity-slideshow__header {
    text-align: left;
}

.flickity-slideshow.is-header-center .flickity-slideshow__header {
    text-align: center;
}

.flickity-slideshow.is-header-center .flickity-slideshow__block-desc {
    margin-left: auto;
    margin-right: auto;
}

.flickity-slideshow.is-header-right .flickity-slideshow__header {
    text-align: right;
}

.flickity-slideshow.is-header-right .flickity-slideshow__block-desc {
    margin-left: auto;
}

.flickity-slideshow__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.flickity-slideshow__bg-fig {
    position: absolute;
    inset: 0;
    margin: 0;
    opacity: 0;
    transition: opacity 0.6s ease;
}

.flickity-slideshow__bg-fig.is-active {
    opacity: 1;
}

.flickity-slideshow__bg-fig img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.flickity-slideshow__bg-overlay {
    position: absolute;
    inset: 0;
    background: var(--rct-flickity-bg-overlay);
    pointer-events: none;
}

.flickity-slideshow__carousel {
    position: relative;
    z-index: 2;
}

.flickity-slideshow__carousel .flickity-viewport {
    overflow: hidden;
    margin-bottom: 0;
}

.flickity-slideshow__slide {
    width: calc(100% / var(--rct-flickity-slides-per-view));
    flex: 0 0 auto;
    padding-inline: 0.35rem;
    outline: none;
}

.flickity-slideshow__slide-inner {
    position: relative;
    padding-top: var(--rct-flickity-slide-height);
    overflow: hidden;
    border-radius: 10px;
}

.flickity-slideshow__content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: var(--rct-flickity-content-gap);
    padding-top: var(--rct-flickity-content-pad-top);
    padding-right: var(--rct-flickity-content-pad-x);
    padding-bottom: var(--rct-flickity-content-pad-bottom);
    padding-left: var(--rct-flickity-content-pad-x);
    z-index: 2;
    background: linear-gradient(180deg, var(--rct-flickity-grad-start) 0%, var(--rct-flickity-grad-mid) 50%, var(--rct-flickity-grad-end) 100%);
    transition: background 0.28s ease;
}

.flickity-slideshow__content::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--rct-flickity-glass-color);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.28s ease;
}

.flickity-slideshow__content > * {
    position: relative;
    z-index: 1;
}

.flickity-slideshow.is-title-bottom .flickity-slideshow__content {
    justify-content: flex-end;
    text-align: center;
    --rct-flickity-grad-start: rgba(0, 0, 0, 0.66);
    --rct-flickity-grad-mid: rgba(0, 0, 0, 0.16);
    --rct-flickity-grad-end: rgba(0, 0, 0, 0.66);
    --rct-flickity-content-pad-top: clamp(1.25rem, 2.1vw, 1.85rem);
    --rct-flickity-content-pad-bottom: clamp(1.25rem, 2.1vw, 1.85rem);
}

.flickity-slideshow.is-title-middle .flickity-slideshow__content {
    justify-content: center;
    text-align: center;
    --rct-flickity-grad-start: rgba(0, 0, 0, 0.56);
    --rct-flickity-grad-mid: rgba(0, 0, 0, 0.22);
    --rct-flickity-grad-end: rgba(0, 0, 0, 0.56);
    --rct-flickity-content-pad-top: clamp(1.1rem, 1.8vw, 1.55rem);
    --rct-flickity-content-pad-bottom: clamp(1.1rem, 1.8vw, 1.55rem);
}

.flickity-slideshow.is-title-middle .flickity-slideshow__title,
.flickity-slideshow.is-title-middle .flickity-slideshow__desc {
    max-width: min(100%, 30ch);
}

.flickity-slideshow.is-title-middle .flickity-slideshow__btn {
    margin-top: 0.3rem;
}

.flickity-slideshow__title {
    font-family: var(--recterior-font-heading, 'Inter', sans-serif);
    font-size: 1.0625rem;
    font-weight: 600;
    text-transform: uppercase;
    line-height: 1.6;
    letter-spacing: 0.5px;
    color: #fff;
    margin: 0;
    max-width: min(100%, var(--rct-flickity-content-max-width));
    transition: color 0.3s ease;
    text-wrap: balance;
}

.flickity-slideshow__desc {
    font-size: 0.875rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.78);
    margin: 0;
    max-width: min(100%, calc(var(--rct-flickity-content-max-width) + 4ch));
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.flickity-slideshow__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: #fff;
    text-decoration: none;
    opacity: 0;
    transform: translateY(14px);
    margin-top: 0.2rem;
    align-self: center;
    transition: opacity 0.4s ease 0.05s, transform 0.4s ease 0.05s, color 0.3s ease;
}

.flickity-slideshow__btn:hover {
    color: var(--recterior-accent, #AC8C66);
}

.flickity-slideshow__btn svg {
    width: 11px;
    height: 9px;
    fill: currentColor;
}

.flickity-slideshow__slide:hover .flickity-slideshow__desc,
.flickity-slideshow__slide:hover .flickity-slideshow__btn,
.flickity-slideshow__slide:focus-within .flickity-slideshow__desc,
.flickity-slideshow__slide:focus-within .flickity-slideshow__btn {
    opacity: 1;
    transform: translateY(0);
}

.flickity-slideshow__slide:hover .flickity-slideshow__title {
    color: var(--recterior-accent, #AC8C66);
}

.flickity-slideshow__slide:focus-within .flickity-slideshow__title {
    color: var(--recterior-accent, #AC8C66);
}

.flickity-slideshow__slide.is-selected .flickity-slideshow__content,
.flickity-slideshow__slide:hover .flickity-slideshow__content,
.flickity-slideshow__slide:focus-within .flickity-slideshow__content {
    background: linear-gradient(180deg, var(--rct-flickity-grad-start) 0%, var(--rct-flickity-grad-mid) 50%, var(--rct-flickity-grad-end) 100%);
}

.flickity-slideshow__slide.is-selected .flickity-slideshow__content::before,
.flickity-slideshow__slide:hover .flickity-slideshow__content::before,
.flickity-slideshow__slide:focus-within .flickity-slideshow__content::before {
    opacity: var(--rct-flickity-glass-opacity);
}

.flickity-slideshow__slide::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 1px;
    background: rgba(255, 255, 255, 0.1);
    z-index: 3;
}

.flickity-slideshow .flickity-prev-next-button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: var(--rct-flickity-arrow-size);
    height: var(--rct-flickity-arrow-size);
    background: rgba(18, 27, 29, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.25);
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s ease;
    color: #fff;
    padding: 0;
}

.flickity-slideshow .flickity-prev-next-button:hover {
    background: rgba(18, 27, 29, 0.82);
}

.flickity-slideshow .flickity-prev-next-button.previous {
    left: calc(var(--rct-flickity-arrow-size) / -2);
}

.flickity-slideshow .flickity-prev-next-button.next {
    right: calc(var(--rct-flickity-arrow-size) / -2);
}

.flickity-slideshow .flickity-prev-next-button svg {
    width: 16px;
    height: 16px;
}

.flickity-slideshow .flickity-prev-next-button .flickity-button-icon {
    position: static;
    display: block;
    width: 16px;
    height: 16px;
    margin: auto;
    left: auto;
    top: auto;
    transform: none;
}

.flickity-slideshow .flickity-slideshow__carousel > .flickity-page-dots {
    position: absolute !important;
    top: calc(100% + var(--rct-flickity-dots-gap)) !important;
    left: 50% !important;
    right: auto !important;
    bottom: auto !important;
    transform: translateX(-50%) !important;
    width: max-content;
    min-width: 96px;
    clear: none;
    margin: 0 !important;
    padding: 0.35rem 0 0;
    list-style: none;
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    z-index: 12;
    background: var(--recterior-bg, #121B1D);
    border-radius: 10px;
    pointer-events: auto;
}

.flickity-slideshow.no-dots .flickity-slideshow__carousel > .flickity-page-dots {
    display: none !important;
}

.flickity-slideshow .flickity-page-dots .dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.26);
    border: 1px solid rgba(255, 255, 255, 0.34);
    cursor: pointer;
    transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease, opacity 0.3s ease;
    opacity: 0.8;
}

.flickity-slideshow .flickity-page-dots .dot.is-selected {
    background: var(--recterior-accent, #AC8C66);
    border-color: var(--recterior-accent, #AC8C66);
    transform: scale(1.15);
    opacity: 1;
    box-shadow: 0 0 0 3px rgba(172, 140, 102, 0.28);
}

@media (max-width: 991.98px) {
    .flickity-slideshow__slide {
        width: 50%;
    }
}

@media (max-width: 767.98px) {
    .flickity-slideshow__slide {
        width: 100%;
    }

    .flickity-slideshow__content {
        --rct-flickity-content-pad-top: 1.15rem;
        --rct-flickity-content-pad-bottom: 1.15rem;
        --rct-flickity-content-pad-x: 0.95rem;
        --rct-flickity-content-gap: 0.45rem;
    }

    .flickity-slideshow .flickity-prev-next-button {
        --rct-flickity-arrow-size: 40px;
    }

    .flickity-slideshow {
        --rct-flickity-arrow-offset: 0.5rem;
        --rct-flickity-dots-gap: 0.65rem;
    }

    .flickity-slideshow__desc,
    .flickity-slideshow__btn {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ==========================================================================
   Gallery Block
   ========================================================================== */
.rct-gallery {
    position: relative;
}

.rct-gallery__title {
    color: var(--recterior-heading-color, inherit);
}

.rct-gallery__grid {
    display: grid;
    grid-template-columns: repeat(var(--rct-gallery-cols, 3), minmax(0, 1fr));
    gap: var(--rct-gallery-gap, 16px);
}

.rct-gallery__grid--isotope {
    display: block;
    margin-left: calc(var(--rct-gallery-gap, 16px) / -2);
    margin-right: calc(var(--rct-gallery-gap, 16px) / -2);
}

.rct-gallery__grid--isotope .rct-gallery__item {
    width: calc(100% / var(--rct-gallery-cols, 3));
    box-sizing: border-box;
    padding-left: calc(var(--rct-gallery-gap, 16px) / 2);
    padding-right: calc(var(--rct-gallery-gap, 16px) / 2);
    margin-bottom: var(--rct-gallery-gap, 16px);
}

.rct-gallery__item {
    break-inside: avoid;
}

.rct-gallery__item-inner,
.rct-gallery__slide-inner {
    margin: 0;
}

.rct-gallery--cards .rct-gallery__item-inner {
    background: var(--recterior-bg-light, #1a2628);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    display: flex;
    flex-direction: column;
}

.rct-gallery--cards .rct-gallery__item-inner > .rct-gallery__image,
.rct-gallery--cards .rct-gallery__item-inner > .rct-gallery__link,
.rct-gallery--cards .rct-gallery__item-inner > .rct-gallery__lightbox-link {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
}

.rct-gallery--rectangle .rct-gallery__item-inner {
    overflow: visible;
}

.rct-gallery--square .rct-gallery__item-inner {
    overflow: visible;
}

.rct-gallery--rectangle .rct-gallery__item-inner > .rct-gallery__image,
.rct-gallery--rectangle .rct-gallery__item-inner > .rct-gallery__link,
.rct-gallery--rectangle .rct-gallery__item-inner > .rct-gallery__lightbox-link {
    display: block;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.rct-gallery--square .rct-gallery__item-inner > .rct-gallery__image,
.rct-gallery--square .rct-gallery__item-inner > .rct-gallery__link,
.rct-gallery--square .rct-gallery__item-inner > .rct-gallery__lightbox-link {
    display: block;
    aspect-ratio: 1;
    overflow: hidden;
}

.rct-gallery__image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.rct-gallery__link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.rct-gallery__link:hover {
    opacity: 0.9;
}

.rct-gallery__caption {
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    line-height: 1.4;
    color: var(--recterior-text-muted, rgba(255, 255, 255, 0.6));
    margin: 0;
}

.rct-gallery--cards .rct-gallery__caption {
    background: var(--recterior-bg-light, #1a2628);
}

/* Slider layout */
.rct-gallery__slider {
    position: relative;
}

.rct-gallery__slider .flickity-viewport {
    overflow: hidden;
}

.rct-gallery__slider .flickity-slider {
    display: flex;
    align-items: stretch;
}

.rct-gallery__slide {
    width: calc(100% / var(--rct-gallery-cols, 3));
    padding: 0 calc(var(--rct-gallery-gap, 16px) / 2);
    display: flex;
}

.rct-gallery__slide-inner {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    width: 100%;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.rct-gallery__slide .rct-gallery__link,
.rct-gallery__slide .rct-gallery__lightbox-link {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
}

.rct-gallery__slide .rct-gallery__image {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.rct-gallery__slide-inner > .rct-gallery__image {
    aspect-ratio: 4 / 3;
}

.rct-gallery__slide .rct-gallery__caption {
    padding: 0.5rem 0.75rem;
    font-size: 0.8125rem;
}

.rct-gallery .flickity-prev-next-button {
    top: 50%;
    transform: translateY(-50%);
}

.rct-gallery .flickity-prev-next-button.previous {
    left: -12px;
}

.rct-gallery .flickity-prev-next-button.next {
    right: -12px;
}

.rct-gallery .flickity-page-dots {
    bottom: -24px;
}

.rct-gallery--lightbox .rct-gallery__item-inner,
.rct-gallery--lightbox .rct-gallery__slide-inner {
    position: relative;
}

.rct-gallery--lightbox .rct-gallery__lightbox-link {
    display: block;
    width: 100%;
}

.rct-gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10000;
}

.rct-gallery-lightbox[hidden] {
    display: none !important;
}

.rct-gallery-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, var(--rct-lightbox-overlay-opacity, 0.9));
}

.rct-gallery-lightbox__dialog {
    position: absolute;
    inset: 2rem;
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: 1fr auto;
    align-items: center;
    gap: 1rem;
}

.rct-gallery-lightbox__media-wrap {
    position: relative;
    min-height: 0;
    text-align: center;
}

.rct-gallery-lightbox__image {
    max-width: min(1200px, 100%);
    max-height: calc(100vh - 8rem);
    width: auto;
    height: auto;
    object-fit: contain;
}

.rct-gallery-lightbox__caption {
    margin: 0.85rem 0 0;
    color: #e6e6e6;
    font-size: 0.95rem;
}

.rct-gallery-lightbox__close,
.rct-gallery-lightbox__nav,
.rct-gallery-lightbox__fullscreen {
    border: 0;
    cursor: pointer;
    color: #fff;
    background: rgba(255, 255, 255, 0.16);
    transition: background 0.2s ease;
}

.rct-gallery-lightbox__close:hover,
.rct-gallery-lightbox__nav:hover,
.rct-gallery-lightbox__fullscreen:hover {
    background: rgba(255, 255, 255, 0.28);
}

.rct-gallery-lightbox__close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 999px;
    font-size: 1.5rem;
    line-height: 1;
    z-index: 2;
}

.rct-gallery-lightbox__nav {
    width: 3rem;
    height: 3rem;
    border-radius: 999px;
    font-size: 1.8rem;
    line-height: 1;
}

.rct-gallery-lightbox__footer {
    grid-column: 1 / -1;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
}

.rct-gallery-lightbox__counter {
    color: #fff;
    font-size: 0.9rem;
}

.rct-gallery-lightbox__fullscreen {
    padding: 0.5rem 0.9rem;
    border-radius: 999px;
    font-size: 0.85rem;
}

.rct-gallery-lightbox--btn-outline .rct-gallery-lightbox__close,
.rct-gallery-lightbox--btn-outline .rct-gallery-lightbox__nav,
.rct-gallery-lightbox--btn-outline .rct-gallery-lightbox__fullscreen {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.65);
}

.rct-gallery-lightbox--btn-minimal .rct-gallery-lightbox__close,
.rct-gallery-lightbox--btn-minimal .rct-gallery-lightbox__nav,
.rct-gallery-lightbox--btn-minimal .rct-gallery-lightbox__fullscreen {
    background: transparent;
    border: 0;
}

.rct-gallery-lightbox--btn-sm .rct-gallery-lightbox__close {
    width: 2.1rem;
    height: 2.1rem;
    font-size: 1.2rem;
}

.rct-gallery-lightbox--btn-sm .rct-gallery-lightbox__nav {
    width: 2.4rem;
    height: 2.4rem;
    font-size: 1.2rem;
}

.rct-gallery-lightbox--btn-sm .rct-gallery-lightbox__fullscreen {
    font-size: 0.75rem;
    padding: 0.4rem 0.75rem;
}

.rct-gallery-lightbox--btn-lg .rct-gallery-lightbox__close {
    width: 3rem;
    height: 3rem;
    font-size: 1.8rem;
}

.rct-gallery-lightbox--btn-lg .rct-gallery-lightbox__nav {
    width: 3.4rem;
    height: 3.4rem;
    font-size: 2rem;
}

.rct-gallery-lightbox--btn-lg .rct-gallery-lightbox__fullscreen {
    font-size: 0.95rem;
    padding: 0.65rem 1.1rem;
}

.rct-gallery-lightbox--caption-top .rct-gallery-lightbox__media-wrap {
    display: flex;
    flex-direction: column;
}

.rct-gallery-lightbox--caption-top .rct-gallery-lightbox__caption {
    order: -1;
    margin: 0 0 0.85rem;
}

.rct-gallery-lightbox--caption-overlay .rct-gallery-lightbox__media-wrap {
    position: relative;
}

.rct-gallery-lightbox--caption-overlay .rct-gallery-lightbox__caption {
    position: absolute;
    left: 0.75rem;
    right: 0.75rem;
    bottom: 0.75rem;
    margin: 0;
    padding: 0.5rem 0.65rem;
    border-radius: 0.5rem;
    background: rgba(0, 0, 0, 0.45);
}

@media (max-width: 767.98px) {
    .rct-gallery-lightbox__dialog {
        inset: 0.75rem;
        gap: 0.5rem;
    }

    .rct-gallery-lightbox__image {
        max-height: calc(100vh - 7rem);
    }

    .rct-gallery-lightbox__nav {
        width: 2.5rem;
        height: 2.5rem;
        font-size: 1.4rem;
    }
}

@media (max-width: 991.98px) {
    .rct-gallery__grid {
        grid-template-columns: repeat(var(--rct-gallery-cols-tablet, 2), minmax(0, 1fr));
    }

    .rct-gallery__grid--isotope .rct-gallery__item {
        width: calc(100% / var(--rct-gallery-cols-tablet, 2));
    }

    .rct-gallery__slide {
        width: calc(100% / var(--rct-gallery-cols-tablet, 2));
    }
}

@media (max-width: 767.98px) {
    .rct-gallery__grid {
        grid-template-columns: repeat(var(--rct-gallery-cols-mobile, 1), minmax(0, 1fr));
    }

    .rct-gallery__grid--isotope .rct-gallery__item {
        width: calc(100% / var(--rct-gallery-cols-mobile, 1));
    }

    .rct-gallery__slide {
        width: 100%;
    }
}

/* ==========================================================================
   Dark Mode Overrides for New Components
   ========================================================================== */
[data-bs-theme="dark"] .pf-sidebar__details {
    background-color: var(--recterior-bg-light);
}

[data-bs-theme="dark"] .pf-sidebar__meta-row {
    border-bottom-color: var(--recterior-border);
}

[data-bs-theme="dark"] .pf-sidebar__label {
    color: var(--recterior-text-muted);
}

[data-bs-theme="dark"] .pf-sidebar__value {
    color: var(--recterior-heading-color);
}

[data-bs-theme="dark"] .pf-sidebar__cta {
    background: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

[data-bs-theme="dark"] .pf-sidebar__cta:hover {
    background: #fff;
    color: #1a1a1a;
}

[data-bs-theme="dark"] .rct-feature-highlight__wrap {
    border-color: var(--recterior-border);
}

[data-bs-theme="dark"] .rct-feature-highlight__info {
    border-right-color: var(--recterior-border);
}

[data-bs-theme="dark"] .rct-feature-highlight__btn {
    background: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

[data-bs-theme="dark"] .rct-feature-highlight__btn:hover {
    background: #fff;
    color: #1a1a1a;
}

[data-bs-theme="dark"] .rct-feature-highlight__checklist li {
    color: var(--recterior-text);
}

@media (max-width: 767.98px) {
    [data-bs-theme="dark"] .rct-feature-highlight__info {
        border-bottom-color: var(--recterior-border);
    }
}

[data-bs-theme="dark"] .rct-ba-label {
    background: rgba(0, 0, 0, 0.65);
}

[data-bs-theme="dark"] .rct-st-carousel .flickity-page-dots .dot,
[data-bs-theme="dark"] .rct-related-posts-slider .flickity-page-dots .dot {
    background: var(--recterior-heading-color);
}

/* ==========================================================================
   Light Mode Overrides
   ========================================================================== */
[data-bs-theme="light"] {
    --recterior-bg: #ffffff;
    --recterior-bg-light: #f5f5f5;
    --recterior-bg-card: #f0f0f0;
    --recterior-text: #333333;
    --recterior-text-muted: #777777;
    --recterior-heading-color: var(--recterior-header-sticky-light-text, #1a1a1a);
    --recterior-white: #ffffff;
    --recterior-border: rgba(0, 0, 0, 0.1);
    --recterior-ui-foreground: rgba(255, 255, 255, 0.86);
    --recterior-ui-foreground-hover: #ffffff;
    --recterior-ui-foreground-muted: rgba(26, 26, 26, 0.72);
    --recterior-header-foreground: var(--recterior-ui-foreground);
    --recterior-header-foreground-hover: var(--recterior-ui-foreground-hover);
    --recterior-header-sticky-foreground: var(--recterior-header-sticky-light-text, #1a1a1a);
    --recterior-header-sticky-foreground-hover: var(--recterior-accent);
    --recterior-header-trigger-foreground: var(--recterior-header-foreground);
    --recterior-header-trigger-sticky-foreground: var(--recterior-header-sticky-foreground);
    --recterior-header-dropdown-bg: #ffffff;
    --recterior-header-dropdown-text: #333333;
    --recterior-header-dropdown-hover-text: #1a1a1a;
    --recterior-header-dropdown-hover-bg: #f5f5f5;
    --recterior-header-sticky-bg: rgba(255, 255, 255, 0.95);
    --recterior-header-sticky-border: rgba(0, 0, 0, 0.06);
    --recterior-header-chip-bg: rgba(16, 22, 24, 0.44);
    --recterior-header-chip-border: rgba(255, 255, 255, 0.26);
    --recterior-header-chip-shadow: 0 10px 28px rgba(0, 0, 0, 0.2);
    --recterior-topbar-blend-mode: difference;
    --recterior-menu-color-muted: rgba(255, 255, 255, 0.76);
    --recterior-menu-color: rgba(255, 255, 255, 0.95);
    --recterior-menu-color-active: #d0a678;
}

[data-bs-theme="light"] .rct-side-drawer__panel {
    background-color: #111a1d;
    color: rgba(255, 255, 255, 0.84);
}

[data-bs-theme="light"] .rct-mobile-menu {
    background-color: #ffffff;
}

[data-bs-theme="light"] .rct-mobile-menu__overlay {
    background-color: rgba(0, 0, 0, 0.3);
}

[data-bs-theme="light"] .contact-form .form-control,
[data-bs-theme="light"] .contact-form .form-select {
    background-color: #f5f5f5;
    color: #333333;
    border-color: rgba(0, 0, 0, 0.12);
}

[data-bs-theme="light"] .contact-form .form-control::placeholder {
    color: #999999;
}

[data-bs-theme="light"] .contact-form .form-control:focus,
[data-bs-theme="light"] .contact-form .form-select:focus {
    border-color: var(--recterior-accent);
    background-color: #ffffff;
}

[data-bs-theme="light"] .numbered-services__number {
    -webkit-text-stroke-color: var(--rct-ns-number-stroke, var(--recterior-theme-bg, #1a1a1a));
    color: transparent;
}

[data-bs-theme="light"] .numbered-services--card-glass .numbered-services__card {
    background-color: rgba(255, 255, 255, 0.16);
}

[data-bs-theme="light"] .numbered-services__card:hover .numbered-services__number {
    -webkit-text-stroke-color: var(--rct-ns-number-stroke-hover, var(--recterior-theme-bg, #1a1a1a));
}

[data-bs-theme="light"] .numbered-services__title {
    color: var(--recterior-heading-color, var(--recterior-text, var(--recterior-heading-color))) !important;
}

[data-bs-theme="light"] .numbered-services__desc {
    color: var(--recterior-text, var(--recterior-text)) !important;
}

[data-bs-theme="light"] .flickity-slideshow__title {
    color: var(--recterior-heading-color);
}

[data-bs-theme="light"] .flickity-slideshow__btn {
    color: var(--recterior-text-muted);
}

[data-bs-theme="light"] .flickity-slideshow__desc {
    color: var(--recterior-text);
}

[data-bs-theme="light"] .flip-card-back {
    background-color: var(--recterior-bg-card);
    border-color: var(--recterior-border);
}

[data-bs-theme="light"] .flip-card-front {
    background-color: var(--recterior-bg-card);
    border-color: var(--recterior-border);
}

[data-bs-theme="light"] .flip-card-front__title {
    color: var(--recterior-heading-color);
}

[data-bs-theme="light"] .flip-card-back__desc {
    color: var(--recterior-text);
}

[data-bs-theme="light"] .counter-box .counter-value {
    color: var(--recterior-heading-color);
}

[data-bs-theme="light"] .cta-section {
    background-color: #f5f5f5;
}

[data-bs-theme="light"] .section-padding {
    color: var(--recterior-text);
}

[data-bs-theme="light"] .hero-slide__content .display-1,
[data-bs-theme="light"] .hero-slide__content .display-3,
[data-bs-theme="light"] .hero-slide__content h1,
[data-bs-theme="light"] .hero-slide__content h2 {
    color: #ffffff;
}

[data-bs-theme="light"] .hero-slide__content p,
[data-bs-theme="light"] .hero-slide__content .lead {
    color: rgba(255, 255, 255, 0.85);
}

[data-bs-theme="light"] .site-footer {
    background-color: var(--recterior-theme-bg, var(--recterior-bg));
    color: #c5c5c5;
}

[data-bs-theme="light"] .site-footer h2,
[data-bs-theme="light"] .site-footer h5,
[data-bs-theme="light"] .site-footer .footer-cta-heading {
    color: #ffffff;
}

[data-bs-theme="light"] .site-footer a {
    color: #c5c5c5;
}

[data-bs-theme="light"] .site-footer a:hover {
    color: var(--recterior-accent);
}

[data-bs-theme="light"] .footer-bottom {
    border-top-color: rgba(255, 255, 255, 0.1);
}

[data-bs-theme="light"] .rct-custom-cursor,
[data-bs-theme="light"] .rct-custom-cursor__dot {
    background-color: #1a1a1a;
}

[data-bs-theme="light"] .rct-scroll-progress__bar {
    background-color: var(--recterior-accent);
}

[data-bs-theme="light"] .rct-preloader {
    background-color: var(--recterior-theme-bg, var(--recterior-bg));
}

[data-bs-theme="light"] .rct-lang-dropdown__toggle:hover {
    color: var(--recterior-accent);
    border-color: var(--recterior-accent);
    background-color: #ffffff;
}

[data-bs-theme="light"] .rct-lang-dropdown__menu {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
}

[data-bs-theme="light"] .rct-lang-dropdown__item.is-active {
    color: var(--recterior-accent);
    background-color: rgba(172, 140, 102, 0.12);
}

[data-bs-theme="light"] .text-white {
    color: var(--recterior-heading-color) !important;
}

[data-bs-theme="light"] .text-white-50 {
    color: var(--recterior-text-muted) !important;
}

[data-bs-theme="light"] .site-footer .text-white,
[data-bs-theme="light"] .hero-slide .text-white,
[data-bs-theme="light"] .hero-slide__content .text-white {
    color: #fff !important;
}

[data-bs-theme="light"] .site-footer .text-white-50 {
    color: rgba(255, 255, 255, 0.5) !important;
}

[data-bs-theme="light"] .bg-dark-custom {
    background-color: #f5f5f5 !important;
}

[data-bs-theme="light"] .bg-dark-light {
    background-color: #f0f0f0 !important;
}

[data-bs-theme="light"] .card.bg-dark {
    background-color: #f5f5f5 !important;
    border-color: rgba(0, 0, 0, 0.1) !important;
}

[data-bs-theme="light"] .card.bg-dark .text-white,
[data-bs-theme="light"] .card.bg-dark .card-title a.text-white {
    color: #1a1a1a !important;
}

[data-bs-theme="light"] .navbar-toggler-icon {
    filter: invert(1);
}

[data-bs-theme="light"] .recterior-navbar .navbar-toggler {
    border-color: rgba(0, 0, 0, 0.15);
}

[data-bs-theme="light"] .btn-outline-light {
    color: #1a1a1a;
    border-color: #1a1a1a;
}

[data-bs-theme="light"] .btn-outline-light:hover {
    background-color: #1a1a1a;
    border-color: #1a1a1a;
    color: #ffffff;
}

[data-bs-theme="light"] .scroll-to-top {
    background-color: var(--recterior-accent);
    color: var(--recterior-accent-contrast);
}

[data-bs-theme="light"] .scroll-to-top:hover {
    background-color: #1a1a1a;
    color: #ffffff;
}

[data-bs-theme="light"] .rct-drawer-trigger {
    color: #1a1a1a;
}

[data-bs-theme="light"] .rct-drawer-trigger:hover {
    color: var(--recterior-accent);
}

[data-bs-theme="light"] .rct-mobile-menu__close-btn svg {
    stroke: #1a1a1a;
}

[data-bs-theme="light"] .rct-mobile-menu .nav-link {
    color: #1a1a1a;
}

[data-bs-theme="light"] .rct-mobile-menu .nav-link:hover {
    color: var(--recterior-accent);
}

[data-bs-theme="light"] .rct-mobile-toggle__bars .bar {
    background: #1a1a1a;
}

[data-bs-theme="light"] .rct-mobile-header .site-title {
    color: #1a1a1a !important;
}

[data-bs-theme="light"] .rct-mobile-nav__close svg,
[data-bs-theme="light"] .rct-mobile-nav__close line {
    stroke: #1a1a1a;
}

[data-bs-theme="light"] .rct-mobile-nav__list > .nav-item > .nav-link {
    color: #1a1a1a;
}

[data-bs-theme="light"] .rct-mobile-nav__list > .nav-item > .nav-link:hover,
[data-bs-theme="light"] .rct-mobile-nav__list > .nav-item > .nav-link:focus {
    color: var(--recterior-accent);
}

[data-bs-theme="light"] .rct-fsm__visual {
    color: #1a1a1a;
}

/* ==========================================================================
   Global Radius Reset
   ========================================================================== */
:root {
    --bs-border-radius: 0;
    --bs-border-radius-sm: 0;
    --bs-border-radius-lg: 0;
    --bs-border-radius-xl: 0;
    --bs-border-radius-xxl: 0;
    --bs-border-radius-pill: 0;
}

/* Exclude WooCommerce product gallery zoom (theme styles it round in woocommerce.css) */
#page,
#page *:not(.woocommerce-product-gallery__trigger),
#page *:not(.woocommerce-product-gallery__trigger)::before,
#page *:not(.woocommerce-product-gallery__trigger)::after {
    border-radius: 0 !important;
}

/* ==========================================================================
   Multi Image Mask Slider Block
   ========================================================================== */
.rct-mask-slider {
    overflow: hidden;
}

.rct-mask-slider__viewport {
    position: relative;
    overflow: hidden;
    min-height: var(--rct-mask-height-desktop, 620px);
    height: var(--rct-mask-height-desktop, 620px);
    background: var(--recterior-bg-light, #11191d);
}

.rct-mask-slider__slide {
    position: absolute;
    inset: 0;
    display: flex;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--rct-mask-transition, 900ms) ease, visibility var(--rct-mask-transition, 900ms) ease;
}

.rct-mask-slider__slide.is-current {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    z-index: 3;
}

.rct-mask-slider__slide.is-leaving {
    opacity: 0;
    visibility: visible;
    z-index: 4;
}

.rct-mask-slider__part {
    position: relative;
    overflow: hidden;
    height: 100%;
}

.rct-mask-slider__fig {
    position: absolute;
    inset: 0;
    margin: 0;
}

.rct-mask-slider__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: scale(1.025);
    transition: transform calc(var(--rct-mask-transition, 900ms) * 1.35) ease, filter calc(var(--rct-mask-transition, 900ms) * 0.85) ease;
}

.rct-mask-slider__slide.is-current .rct-mask-slider__img {
    transform: scale(1);
}

.rct-mask-slider__slide.is-entering .rct-mask-slider__part {
    animation: rctMaskPartIn var(--rct-mask-transition, 900ms) cubic-bezier(0.22, 0.61, 0.36, 1) both;
    animation-delay: calc(var(--rct-mask-part-index, 0) * 70ms);
}

.rct-mask-slider__slide.is-leaving .rct-mask-slider__part {
    animation: rctMaskPartOut var(--rct-mask-transition, 900ms) ease both;
    animation-delay: calc(var(--rct-mask-part-index, 0) * 30ms);
}

@keyframes rctMaskPartIn {
    0% { transform: translateY(20%); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
}

@keyframes rctMaskPartOut {
    0% { transform: translateY(0); opacity: 1; }
    100% { transform: translateY(-16%); opacity: 0; }
}

/* ==========================================================================
   Clients Logos Block
   ========================================================================== */
.rct-clients-logos {
    position: relative;
}

.rct-clients-logos__heading {
    margin-bottom: 30px;
    color: var(--recterior-heading-color);
}

.rct-clients-logos__logo {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    margin: 0 auto;
    opacity: var(--rct-cl-opacity, 1);
    filter: none;
    transition: opacity 0.3s ease, filter 0.3s ease, transform 0.3s ease;
}

.rct-clients-logos.is-monochrome .rct-clients-logos__logo {
    filter: grayscale(1);
}

.rct-clients-logos__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.rct-clients-logos__logo-box {
    width: var(--rct-cl-item-box-width, var(--rct-cl-box-width, 200px));
    height: var(--rct-cl-item-box-height, var(--rct-cl-box-height, 110px));
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    background: var(--rct-cl-item-box-bg, var(--rct-cl-box-bg, transparent));
    padding: var(--rct-cl-box-padding, 10px);
    border-radius: var(--rct-cl-box-radius, 0);
}

.rct-clients-logos__link:hover .rct-clients-logos__logo,
.rct-clients-logos__link:focus .rct-clients-logos__logo,
.rct-clients-logos__link:focus-visible .rct-clients-logos__logo,
.rct-clients-logos__grid-cell:hover .rct-clients-logos__logo,
.rct-clients-logos__cell:hover .rct-clients-logos__logo {
    opacity: var(--rct-cl-opacity-hover, 1);
    filter: none;
}

.rct-clients-logos__grid {
    display: grid;
    grid-template-columns: repeat(var(--rct-cl-cols-desktop, 4), minmax(0, 1fr));
}

.rct-clients-logos__grid.has-borders {
    border-top: 1px solid var(--recterior-border);
    border-left: 1px solid var(--recterior-border);
}

.rct-clients-logos__grid-cell {
    min-height: 240px;
    padding: var(--rct-cl-cell-padding, 100px) 15px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.rct-clients-logos__grid.has-borders .rct-clients-logos__grid-cell {
    border-right: 1px solid var(--recterior-border);
    border-bottom: 1px solid var(--recterior-border);
}

.rct-clients-logos__carousel {
    width: 100%;
}

.rct-clients-logos__carousel-wrap {
    position: relative;
}

.rct-clients-logos__carousel-wrap--full {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: clamp(12px, 2vw, 28px);
    padding-right: clamp(12px, 2vw, 28px);
}

.rct-clients-logos__carousel .flickity-viewport {
    overflow: hidden;
    min-height: 120px;
}

.rct-clients-logos.has-edge-mask .rct-clients-logos__carousel .flickity-viewport {
    -webkit-mask-image: linear-gradient(
        to right,
        transparent 0%,
        #000 var(--rct-cl-mask-width, 6%),
        #000 calc(100% - var(--rct-cl-mask-width, 6%)),
        transparent 100%
    );
    mask-image: linear-gradient(
        to right,
        transparent 0%,
        #000 var(--rct-cl-mask-width, 6%),
        #000 calc(100% - var(--rct-cl-mask-width, 6%)),
        transparent 100%
    );
}

.rct-clients-logos__carousel .rct-clients-logos__cell {
    width: var(--rct-cl-item-cell-width, var(--rct-cl-cell-width, 200px));
    margin-right: var(--rct-cl-logo-spacing, 64px);
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.rct-clients-logos__carousel .rct-clients-logos__logo,
.rct-clients-logos__grid .rct-clients-logos__logo {
    flex: 0 0 auto;
}

.rct-clients-logos__grid .rct-clients-logos__logo-box {
    max-width: 100%;
}

.rct-clients-logos__carousel .flickity-slider {
    display: flex;
    align-items: center;
}

[data-bs-theme="light"] .rct-clients-logos__grid.has-borders,
[data-bs-theme="light"] .rct-clients-logos__grid.has-borders .rct-clients-logos__grid-cell {
    border-color: rgba(0, 0, 0, 0.12);
}

[data-bs-theme="light"] .rct-clients-logos__logo {
    filter: none;
    opacity: 0.9;
}

@media (max-width: 991.98px) {
    .rct-mask-slider__viewport {
        min-height: var(--rct-mask-height-tablet, 460px);
        height: var(--rct-mask-height-tablet, 460px);
    }

    .rct-clients-logos__grid {
        grid-template-columns: repeat(var(--rct-cl-cols-tablet, 2), minmax(0, 1fr));
    }

    .rct-clients-logos__grid-cell {
        min-height: 140px;
        padding-top: calc(var(--rct-cl-cell-padding, 100px) * 0.4);
        padding-bottom: calc(var(--rct-cl-cell-padding, 100px) * 0.4);
    }
}

@media (max-width: 767.98px) {
    .rct-mask-slider__viewport {
        min-height: var(--rct-mask-height-mobile, 320px);
        height: var(--rct-mask-height-mobile, 320px);
    }

    .rct-clients-logos__grid {
        grid-template-columns: repeat(var(--rct-cl-cols-mobile, 2), minmax(0, 1fr));
    }

    .rct-clients-logos__grid-cell {
        min-height: 110px;
        padding-top: calc(var(--rct-cl-cell-padding, 100px) * 0.4);
        padding-bottom: calc(var(--rct-cl-cell-padding, 100px) * 0.4);
        padding-left: 12px;
        padding-right: 12px;
    }

    .rct-clients-logos__logo-box {
        height: calc(var(--rct-cl-item-box-height, var(--rct-cl-box-height, 110px)) * 0.78);
    }

    .rct-clients-logos__carousel .rct-clients-logos__cell {
        margin-right: calc(var(--rct-cl-logo-spacing, 64px) * 0.62);
        width: calc(var(--rct-cl-cell-width, 200px) * 0.72);
    }
}

/* ==========================================================================
   Archive Listing Block
   ========================================================================== */
.rct-archive-listing {
    position: relative;
}

.rct-archive-listing__items {
    --rct-archive-gap: 1.5rem;
    position: relative;
}

.rct-archive-listing .rct-archive-item {
    margin-bottom: 0;
    transition: opacity 0.32s ease, transform 0.32s ease;
    will-change: transform, opacity;
}

.rct-archive-listing .rct-archive-item.rct-archive-item--enter {
    opacity: 0;
    transform: translate3d(0, 14px, 0);
}

.rct-archive-listing .rct-archive-item.rct-archive-item--enter.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.rct-archive-card__inner {
    border: 1px solid var(--recterior-border);
    background: var(--recterior-bg-card, rgba(255, 255, 255, 0.03));
    display: flex;
    flex-direction: column;
    height: 100%;
}

.rct-archive-card__media {
    position: relative;
    overflow: hidden;
    background: var(--recterior-bg-light, #1a2628);
}

.rct-archive-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.rct-archive-card__placeholder {
    height: 280px;
    background: linear-gradient(120deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
}

.rct-archive-card--shape-square .rct-archive-card__media {
    aspect-ratio: 1 / 1;
}

.rct-archive-card--shape-rectangle .rct-archive-card__media {
    aspect-ratio: 4 / 3;
}

.rct-archive-card--shape-masonry .rct-archive-card__media {
    aspect-ratio: auto;
}

.rct-archive-card--shape-masonry .rct-archive-card__image {
    height: auto;
}

.rct-archive-card__content {
    padding: 1.2rem;
}

/* Card Grid: keep thumbnail and card heights visually consistent. */
.rct-archive-card--grid .rct-archive-card__media {
    height: 240px;
    aspect-ratio: auto;
}

.rct-archive-card--grid .rct-archive-card__placeholder {
    height: 240px;
}

.rct-archive-card--grid .rct-archive-card__content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.rct-archive-card--grid .rct-archive-card__title a {
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.rct-archive-card--grid .rct-archive-card__excerpt {
    display: block;
    overflow: visible;
}

.rct-archive-card--grid .rct-archive-card__cta {
    margin-top: auto;
}

/* Masonry: preserve natural variable image/card heights. */
.rct-archive-card--masonry .rct-archive-card__media,
.rct-archive-card--shape-masonry .rct-archive-card__media {
    height: auto;
    aspect-ratio: auto;
}

.rct-archive-card--masonry .rct-archive-card__placeholder,
.rct-archive-card--shape-masonry .rct-archive-card__placeholder {
    height: auto;
    min-height: 200px;
}

.rct-archive-card__terms a {
    color: var(--recterior-accent);
    text-decoration: none;
}

.rct-archive-card__title a {
    color: var(--recterior-heading-color, #fff);
}

.rct-archive-card__title a:hover,
.rct-archive-card__title a:focus {
    color: var(--recterior-accent);
}

.rct-archive-card__meta,
.rct-archive-card__excerpt {
    color: var(--recterior-text-muted, #9fa6ad);
}

.rct-archive-card__cta {
    margin-top: 0.9rem;
}

.rct-archive-card--list .rct-archive-card__inner {
    flex-direction: row;
    align-items: stretch;
}

.rct-archive-card--list .rct-archive-card__media {
    width: 38%;
    min-height: 100%;
}

.rct-archive-card--list .rct-archive-card__content {
    width: 62%;
}

.rct-archive-listing.is-loading .rct-archive-listing__load-more {
    opacity: 0.5;
    pointer-events: none;
}

.rct-archive-listing.is-loading .rct-archive-listing__items::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -6px;
    width: 28px;
    height: 28px;
    margin-left: -14px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: var(--recterior-accent);
    animation: rct-archive-spin 0.75s linear infinite;
    pointer-events: none;
}

.rct-archive-listing__sentinel {
    width: 1px;
    height: 1px;
    margin: 0 auto;
}

.rct-archive-listing__end {
    text-align: center;
}

@keyframes rct-archive-spin {
    to {
        transform: rotate(360deg);
    }
}

.rct-archive-listing .page-numbers {
    margin-bottom: 0;
}

.rct-archive-listing .pagination-wrap .nav-links {
    display: flex;
    justify-content: center;
}

.rct-archive-listing .pagination-wrap ul.page-numbers {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.rct-archive-listing .pagination-wrap a.page-numbers,
.rct-archive-listing .pagination-wrap span.page-numbers {
    min-width: 2.5rem;
    width: auto;
    padding: 0 0.7rem;
    white-space: nowrap;
}

.rct-archive-listing .pagination-wrap a.page-numbers.prev,
.rct-archive-listing .pagination-wrap a.page-numbers.next {
    min-width: 5.5rem;
    padding: 0 1rem;
}

/* Fallback when WP does not output prev/next classes. */
.rct-archive-listing .pagination-wrap ul.page-numbers > li:first-child > a.page-numbers,
.rct-archive-listing .pagination-wrap ul.page-numbers > li:last-child > a.page-numbers {
    min-width: 5.5rem;
    padding: 0 1rem;
}

.rct-archive-listing__items[data-rct-archive-layout="grid"] .rct-archive-card__media,
.rct-archive-listing__items[data-rct-archive-layout="grid"] .rct-archive-card__placeholder {
    height: 240px;
    aspect-ratio: auto;
}

.rct-archive-listing__items[data-rct-archive-layout="masonry"] .rct-archive-card__media,
.rct-archive-listing__items[data-rct-archive-layout="masonry"] .rct-archive-card__placeholder {
    height: auto;
    aspect-ratio: auto;
}

[data-bs-theme="light"] .rct-archive-card__inner {
    background: #ffffff;
}

[data-bs-theme="light"] .rct-archive-card__meta,
[data-bs-theme="light"] .rct-archive-card__excerpt {
    color: #6c757d;
}

@media (max-width: 991.98px) {
    .rct-archive-card--grid .rct-archive-card__media,
    .rct-archive-card--grid .rct-archive-card__placeholder {
        height: 220px;
    }

    .rct-archive-card--list .rct-archive-card__inner {
        flex-direction: column;
    }

    .rct-archive-card--list .rct-archive-card__media,
    .rct-archive-card--list .rct-archive-card__content {
        width: 100%;
    }

    .rct-archive-listing .pagination-wrap a.page-numbers.prev,
    .rct-archive-listing .pagination-wrap a.page-numbers.next,
    .rct-archive-listing .pagination-wrap ul.page-numbers > li:first-child > a.page-numbers,
    .rct-archive-listing .pagination-wrap ul.page-numbers > li:last-child > a.page-numbers {
        min-width: 4.25rem;
        padding: 0 0.75rem;
    }
}

@media (min-width: 1200px) {
    .rct-archive-card--grid .rct-archive-card__media,
    .rct-archive-card--grid .rct-archive-card__placeholder {
        height: 260px;
    }
}
