/*
Theme Name: Angela Racheal Portfolio
Theme URI: https://angelaracheal.com
Author: Triad Digital Solutions
Author URI: https://triadng.com
Description: A bold, animated portfolio theme for Angela Racheal — graphic designer & copywriter. Built for WordPress + Elementor Flex mode. Boldnote-inspired with enhanced animations and text interactions.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: angelaracheal
Tags: portfolio, one-page, custom-colors, custom-logo, elementor, flex-layout, animation

Angela Racheal Portfolio Theme — Designed & Developed by Triad Digital Solutions (triadng.com)
*/

/* ============================================
   CSS CUSTOM PROPERTIES (CUSTOMIZABLE)
   ============================================ */
:root {
    /* Primary Colors — Boldnote-inspired warm palette */
    --ar-color-primary: #1a1a1a;
    --ar-color-secondary: #f5f0eb;
    --ar-color-accent: #c9a87c;
    --ar-color-accent-hover: #b8956a;
    --ar-color-dark: #0d0d0d;
    --ar-color-light: #ffffff;
    --ar-color-grey: #999999;
    --ar-color-grey-light: #e8e3de;
    --ar-color-text: #333333;
    --ar-color-text-light: #666666;
    --ar-color-border: #e0dbd5;

    /* Typography */
    --ar-font-heading: 'Playfair Display', Georgia, serif;
    --ar-font-body: 'DM Sans', 'Helvetica Neue', sans-serif;
    --ar-font-accent: 'Space Mono', monospace;
    --ar-font-size-base: 16px;
    --ar-font-size-sm: 14px;
    --ar-font-size-xs: 12px;
    --ar-font-size-lg: 18px;
    --ar-font-size-xl: 24px;
    --ar-font-size-2xl: 36px;
    --ar-font-size-3xl: 48px;
    --ar-font-size-4xl: 64px;
    --ar-font-size-hero: clamp(48px, 8vw, 120px);
    --ar-font-size-display: clamp(36px, 6vw, 80px);

    /* Spacing */
    --ar-spacing-xs: 8px;
    --ar-spacing-sm: 16px;
    --ar-spacing-md: 24px;
    --ar-spacing-lg: 40px;
    --ar-spacing-xl: 64px;
    --ar-spacing-2xl: 100px;
    --ar-spacing-section: clamp(80px, 10vw, 160px);

    /* Layout */
    --ar-container-max: 1400px;
    --ar-container-narrow: 900px;
    --ar-border-radius: 0px;
    --ar-transition: 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --ar-transition-slow: 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --ar-transition-spring: 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
}

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

html {
    font-size: var(--ar-font-size-base);
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    font-family: var(--ar-font-body);
    font-size: var(--ar-font-size-base);
    line-height: 1.7;
    color: var(--ar-color-text);
    background-color: var(--ar-color-secondary);
    overflow-x: hidden;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--ar-font-heading);
    font-weight: 700;
    line-height: 1.15;
    color: var(--ar-color-primary);
    letter-spacing: -0.02em;
}

h1 { font-size: var(--ar-font-size-hero); }
h2 { font-size: var(--ar-font-size-display); }
h3 { font-size: var(--ar-font-size-3xl); }
h4 { font-size: var(--ar-font-size-2xl); }
h5 { font-size: var(--ar-font-size-xl); }
h6 { font-size: var(--ar-font-size-lg); }

p {
    margin-bottom: 1.5em;
    color: var(--ar-color-text-light);
}

a {
    color: var(--ar-color-primary);
    text-decoration: none;
    transition: var(--ar-transition);
}

a:hover {
    color: var(--ar-color-accent);
}

/* ============================================
   LAYOUT CONTAINERS
   ============================================ */
.ar-container {
    max-width: var(--ar-container-max);
    margin: 0 auto;
    padding: 0 var(--ar-spacing-lg);
}

.ar-container--narrow {
    max-width: var(--ar-container-narrow);
}

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

/* ============================================
   HEADER & NAVIGATION
   ============================================ */
.ar-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    padding: var(--ar-spacing-md) var(--ar-spacing-lg);
    transition: var(--ar-transition);
    mix-blend-mode: difference;
}

.ar-header.scrolled {
    background: rgba(245, 240, 235, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    mix-blend-mode: normal;
    box-shadow: 0 1px 0 var(--ar-color-border);
}

.ar-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: var(--ar-container-max);
    margin: 0 auto;
}

.ar-header__logo {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-xl);
    font-weight: 700;
    color: var(--ar-color-light);
    letter-spacing: -0.03em;
    transition: var(--ar-transition);
}

.ar-header.scrolled .ar-header__logo {
    color: var(--ar-color-primary);
}

.ar-header__logo a {
    color: inherit;
}

.ar-nav {
    display: flex;
    align-items: center;
    gap: var(--ar-spacing-lg);
}

.ar-nav__link {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--ar-color-light);
    position: relative;
    padding: 4px 0;
}

.ar-header.scrolled .ar-nav__link {
    color: var(--ar-color-primary);
}

.ar-nav__link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 1px;
    background: currentColor;
    transition: var(--ar-transition);
}

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

/* Mobile Menu Toggle */
.ar-menu-toggle {
    display: none;
    flex-direction: column;
    gap: 6px;
    cursor: pointer;
    padding: 8px;
    z-index: 1001;
}

.ar-menu-toggle__bar {
    width: 28px;
    height: 2px;
    background: var(--ar-color-light);
    transition: var(--ar-transition);
    transform-origin: center;
}

.ar-header.scrolled .ar-menu-toggle__bar {
    background: var(--ar-color-primary);
}

.ar-menu-toggle.active .ar-menu-toggle__bar:nth-child(1) {
    transform: rotate(45deg) translate(5px, 6px);
}

.ar-menu-toggle.active .ar-menu-toggle__bar:nth-child(2) {
    opacity: 0;
}

.ar-menu-toggle.active .ar-menu-toggle__bar:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -6px);
}

/* Mobile Navigation Overlay */
.ar-mobile-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--ar-color-dark);
    z-index: 999;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--ar-spacing-lg);
    opacity: 0;
    visibility: hidden;
    transition: var(--ar-transition-slow);
}

.ar-mobile-nav.active {
    opacity: 1;
    visibility: visible;
}

.ar-mobile-nav__link {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-3xl);
    color: var(--ar-color-light);
    transform: translateY(30px);
    opacity: 0;
    transition: var(--ar-transition);
}

.ar-mobile-nav.active .ar-mobile-nav__link {
    transform: translateY(0);
    opacity: 1;
}

.ar-mobile-nav.active .ar-mobile-nav__link:nth-child(1) { transition-delay: 0.1s; }
.ar-mobile-nav.active .ar-mobile-nav__link:nth-child(2) { transition-delay: 0.15s; }
.ar-mobile-nav.active .ar-mobile-nav__link:nth-child(3) { transition-delay: 0.2s; }
.ar-mobile-nav.active .ar-mobile-nav__link:nth-child(4) { transition-delay: 0.25s; }
.ar-mobile-nav.active .ar-mobile-nav__link:nth-child(5) { transition-delay: 0.3s; }

/* ============================================
   HERO SECTION
   ============================================ */
.ar-hero {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: var(--ar-spacing-2xl) var(--ar-spacing-lg);
    background: var(--ar-color-dark);
    position: relative;
    overflow: hidden;
}

.ar-hero__bg {
    position: absolute;
    inset: 0;
    opacity: 0.15;
    background-size: cover;
    background-position: center;
    filter: grayscale(30%);
}

.ar-hero__content {
    position: relative;
    z-index: 2;
    max-width: 900px;
}

.ar-hero__headline {
    font-size: var(--ar-font-size-hero);
    color: var(--ar-color-light);
    line-height: 1.05;
    margin-bottom: var(--ar-spacing-md);
}

.ar-hero__headline .word {
    display: inline-block;
    overflow: hidden;
}

.ar-hero__headline .word-inner {
    display: inline-block;
    transform: translateY(110%);
    transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.ar-hero__headline.animate .word-inner {
    transform: translateY(0);
}

.ar-hero__sub {
    font-size: var(--ar-font-size-lg);
    color: var(--ar-color-grey);
    max-width: 600px;
    line-height: 1.7;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.8s ease 0.6s;
}

.ar-hero__sub.animate {
    opacity: 1;
    transform: translateY(0);
}

.ar-hero__cta {
    margin-top: var(--ar-spacing-lg);
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.8s ease 0.8s;
}

.ar-hero__cta.animate {
    opacity: 1;
    transform: translateY(0);
}

/* ============================================
   BUTTONS
   ============================================ */
.ar-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--ar-spacing-sm);
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    padding: 16px 36px;
    border: 1px solid currentColor;
    background: transparent;
    color: var(--ar-color-light);
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: var(--ar-transition);
}

.ar-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: var(--ar-color-accent);
    transition: var(--ar-transition);
    z-index: -1;
}

.ar-btn:hover {
    color: var(--ar-color-dark);
    border-color: var(--ar-color-accent);
}

.ar-btn:hover::before {
    left: 0;
}

.ar-btn--dark {
    color: var(--ar-color-primary);
}

.ar-btn--dark:hover {
    color: var(--ar-color-dark);
}

.ar-btn__arrow {
    width: 24px;
    height: 1px;
    background: currentColor;
    position: relative;
    transition: var(--ar-transition);
}

.ar-btn__arrow::after {
    content: '';
    position: absolute;
    right: 0;
    top: -3px;
    width: 8px;
    height: 8px;
    border-right: 1px solid currentColor;
    border-top: 1px solid currentColor;
    transform: rotate(45deg);
}

.ar-btn:hover .ar-btn__arrow {
    width: 36px;
}

/* ============================================
   PORTFOLIO GRID
   ============================================ */
.ar-portfolio {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--ar-spacing-lg);
}

.ar-portfolio__item {
    position: relative;
    overflow: hidden;
    cursor: pointer;
}

.ar-portfolio__image {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.ar-portfolio__item:hover .ar-portfolio__image {
    transform: scale(1.05);
}

.ar-portfolio__overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--ar-spacing-lg);
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.7));
    transform: translateY(20px);
    opacity: 0;
    transition: var(--ar-transition);
}

.ar-portfolio__item:hover .ar-portfolio__overlay {
    transform: translateY(0);
    opacity: 1;
}

.ar-portfolio__number {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    color: var(--ar-color-accent);
    letter-spacing: 0.1em;
    margin-bottom: var(--ar-spacing-xs);
}

.ar-portfolio__category {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--ar-color-grey);
    margin-bottom: var(--ar-spacing-xs);
}

.ar-portfolio__title {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-xl);
    color: var(--ar-color-light);
}

/* Numbered Portfolio (Boldnote-style) */
.ar-portfolio--numbered {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.ar-portfolio--numbered .ar-portfolio__item {
    display: grid;
    grid-template-columns: 100px 1fr 1fr;
    gap: var(--ar-spacing-lg);
    align-items: center;
    padding: var(--ar-spacing-xl) 0;
    border-bottom: 1px solid var(--ar-color-border);
}

.ar-portfolio--numbered .ar-portfolio__item:hover {
    background: rgba(201, 168, 124, 0.05);
}

/* ============================================
   MARQUEE / SCROLLING TEXT
   ============================================ */
.ar-marquee {
    overflow: hidden;
    padding: var(--ar-spacing-xl) 0;
    border-top: 1px solid var(--ar-color-border);
    border-bottom: 1px solid var(--ar-color-border);
}

.ar-marquee__track {
    display: flex;
    animation: marquee-scroll 25s linear infinite;
    width: max-content;
}

.ar-marquee__text {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-display);
    white-space: nowrap;
    padding-right: var(--ar-spacing-xl);
    color: var(--ar-color-primary);
    font-style: italic;
    opacity: 0.8;
}

.ar-marquee__text .separator {
    display: inline-block;
    width: 16px;
    height: 16px;
    background: var(--ar-color-accent);
    border-radius: 50%;
    margin: 0 var(--ar-spacing-lg);
    vertical-align: middle;
}

@keyframes marquee-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.ar-marquee--reverse .ar-marquee__track {
    animation-direction: reverse;
}

/* ============================================
   SERVICES SECTION
   ============================================ */
.ar-services {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--ar-spacing-lg);
}

.ar-service-card {
    padding: var(--ar-spacing-xl);
    border: 1px solid var(--ar-color-border);
    position: relative;
    overflow: hidden;
    transition: var(--ar-transition);
}

.ar-service-card::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 3px;
    background: var(--ar-color-accent);
    transition: var(--ar-transition-slow);
}

.ar-service-card:hover::before {
    width: 100%;
}

.ar-service-card:hover {
    border-color: var(--ar-color-accent);
    transform: translateY(-4px);
}

.ar-service-card__number {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    color: var(--ar-color-accent);
    letter-spacing: 0.1em;
    margin-bottom: var(--ar-spacing-md);
}

.ar-service-card__title {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-xl);
    margin-bottom: var(--ar-spacing-sm);
}

.ar-service-card__desc {
    font-size: var(--ar-font-size-sm);
    color: var(--ar-color-text-light);
    line-height: 1.7;
}

/* ============================================
   AWARDS TICKER
   ============================================ */
.ar-awards {
    background: var(--ar-color-dark);
    padding: var(--ar-spacing-xl) 0;
    overflow: hidden;
}

.ar-awards__track {
    display: flex;
    animation: marquee-scroll 30s linear infinite;
    width: max-content;
}

.ar-awards__item {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-xl);
    color: var(--ar-color-light);
    white-space: nowrap;
    padding-right: var(--ar-spacing-2xl);
    opacity: 0.6;
    transition: var(--ar-transition);
}

.ar-awards__item:hover {
    opacity: 1;
    color: var(--ar-color-accent);
}

/* ============================================
   CLIENT LOGOS
   ============================================ */
.ar-clients {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--ar-spacing-xl);
    padding: var(--ar-spacing-xl) 0;
}

.ar-clients__logo {
    max-width: 120px;
    max-height: 50px;
    opacity: 0.5;
    filter: grayscale(100%);
    transition: var(--ar-transition);
}

.ar-clients__logo:hover {
    opacity: 1;
    filter: grayscale(0%);
}

/* ============================================
   BLOG PREVIEW
   ============================================ */
.ar-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ar-spacing-lg);
}

.ar-blog-card__image {
    width: 100%;
    aspect-ratio: 16/10;
    object-fit: cover;
    margin-bottom: var(--ar-spacing-md);
    transition: transform var(--ar-transition-slow);
}

.ar-blog-card:hover .ar-blog-card__image {
    transform: scale(1.03);
}

.ar-blog-card__meta {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ar-color-grey);
    margin-bottom: var(--ar-spacing-xs);
}

.ar-blog-card__title {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-xl);
}

/* ============================================
   FOOTER
   ============================================ */
.ar-footer {
    background: var(--ar-color-dark);
    color: var(--ar-color-light);
    padding: var(--ar-spacing-2xl) var(--ar-spacing-lg);
}

.ar-footer__inner {
    max-width: var(--ar-container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: var(--ar-spacing-xl);
}

.ar-footer__cta-headline {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-3xl);
    color: var(--ar-color-light);
    margin-bottom: var(--ar-spacing-md);
}

.ar-footer__cta-headline a {
    color: var(--ar-color-accent);
    text-decoration: underline;
    text-underline-offset: 4px;
}

.ar-footer__label {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--ar-color-grey);
    margin-bottom: var(--ar-spacing-sm);
}

.ar-footer__link {
    display: block;
    color: var(--ar-color-light);
    font-size: var(--ar-font-size-sm);
    margin-bottom: var(--ar-spacing-xs);
    transition: var(--ar-transition);
}

.ar-footer__link:hover {
    color: var(--ar-color-accent);
}

.ar-footer__bottom {
    max-width: var(--ar-container-max);
    margin: var(--ar-spacing-xl) auto 0;
    padding-top: var(--ar-spacing-md);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ar-footer__copyright {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    color: var(--ar-color-grey);
}

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

.ar-footer__social-link {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ar-color-grey);
}

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

/* ============================================
   ABOUT PAGE
   ============================================ */
.ar-about-bio {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: var(--ar-spacing-2xl);
    align-items: start;
}

.ar-about-bio__text p {
    font-size: var(--ar-font-size-lg);
    line-height: 1.8;
}

.ar-about-sidebar__item {
    margin-bottom: var(--ar-spacing-md);
    padding-bottom: var(--ar-spacing-md);
    border-bottom: 1px solid var(--ar-color-border);
}

.ar-about-sidebar__label {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--ar-color-grey);
    margin-bottom: 4px;
}

.ar-about-sidebar__value {
    font-size: var(--ar-font-size-base);
    color: var(--ar-color-primary);
}

/* Timeline */
.ar-timeline {
    position: relative;
    padding-left: var(--ar-spacing-xl);
}

.ar-timeline::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--ar-color-border);
}

.ar-timeline__item {
    position: relative;
    margin-bottom: var(--ar-spacing-lg);
    padding-bottom: var(--ar-spacing-lg);
}

.ar-timeline__item::before {
    content: '';
    position: absolute;
    left: calc(-1 * var(--ar-spacing-xl) - 4px);
    top: 8px;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--ar-color-accent);
}

.ar-timeline__year {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    color: var(--ar-color-accent);
    letter-spacing: 0.1em;
    margin-bottom: 4px;
}

.ar-timeline__role {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-lg);
    margin-bottom: 4px;
}

.ar-timeline__company {
    font-size: var(--ar-font-size-sm);
    color: var(--ar-color-text-light);
}

/* ============================================
   CONTACT PAGE
   ============================================ */
.ar-contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ar-spacing-2xl);
}

.ar-contact-form .wpcf7-form-control {
    width: 100%;
    padding: 16px 0;
    border: none;
    border-bottom: 1px solid var(--ar-color-border);
    background: transparent;
    font-family: var(--ar-font-body);
    font-size: var(--ar-font-size-base);
    color: var(--ar-color-primary);
    transition: var(--ar-transition);
}

.ar-contact-form .wpcf7-form-control:focus {
    outline: none;
    border-bottom-color: var(--ar-color-accent);
}

.ar-contact-form textarea.wpcf7-form-control {
    min-height: 120px;
    resize: vertical;
}

/* ============================================
   SINGLE PORTFOLIO
   ============================================ */
.ar-project-hero {
    min-height: 60vh;
    display: flex;
    align-items: flex-end;
    padding: var(--ar-spacing-2xl) var(--ar-spacing-lg);
    background: var(--ar-color-dark);
}

.ar-project-meta {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--ar-spacing-lg);
    padding: var(--ar-spacing-xl) 0;
    border-bottom: 1px solid var(--ar-color-border);
}

.ar-project-meta__label {
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--ar-color-grey);
    margin-bottom: 4px;
}

.ar-project-meta__value {
    font-size: var(--ar-font-size-base);
    color: var(--ar-color-primary);
}

.ar-project-gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--ar-spacing-md);
    padding: var(--ar-spacing-xl) 0;
}

.ar-project-gallery img {
    width: 100%;
    height: auto;
}

/* ============================================
   SCROLL ANIMATIONS
   ============================================ */
.ar-reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.ar-reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

.ar-reveal--left {
    transform: translateX(-40px);
}

.ar-reveal--left.visible {
    transform: translateX(0);
}

.ar-reveal--right {
    transform: translateX(40px);
}

.ar-reveal--right.visible {
    transform: translateX(0);
}

.ar-reveal--scale {
    transform: scale(0.95);
}

.ar-reveal--scale.visible {
    transform: scale(1);
}

/* Staggered children */
.ar-stagger > * {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.ar-stagger.visible > *:nth-child(1) { transition-delay: 0.05s; }
.ar-stagger.visible > *:nth-child(2) { transition-delay: 0.1s; }
.ar-stagger.visible > *:nth-child(3) { transition-delay: 0.15s; }
.ar-stagger.visible > *:nth-child(4) { transition-delay: 0.2s; }
.ar-stagger.visible > *:nth-child(5) { transition-delay: 0.25s; }
.ar-stagger.visible > *:nth-child(6) { transition-delay: 0.3s; }

.ar-stagger.visible > * {
    opacity: 1;
    transform: translateY(0);
}

/* Text split animation */
.ar-split-text .char {
    display: inline-block;
    opacity: 0;
    transform: translateY(100%);
    transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.ar-split-text.visible .char {
    opacity: 1;
    transform: translateY(0);
}

/* Magnetic hover effect for buttons */
.ar-magnetic {
    transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Smooth cursor follower */
.ar-cursor {
    width: 20px;
    height: 20px;
    border: 1px solid var(--ar-color-accent);
    border-radius: 50%;
    position: fixed;
    pointer-events: none;
    z-index: 9999;
    transition: width 0.3s, height 0.3s, border-color 0.3s;
    transform: translate(-50%, -50%);
    mix-blend-mode: difference;
}

.ar-cursor.hover {
    width: 50px;
    height: 50px;
    border-color: var(--ar-color-accent);
    background: rgba(201, 168, 124, 0.1);
}

/* ============================================
   PAGE HEADERS (Non-home pages)
   ============================================ */
.ar-page-header {
    padding: calc(var(--ar-spacing-2xl) + 80px) var(--ar-spacing-lg) var(--ar-spacing-xl);
    background: var(--ar-color-dark);
}

.ar-page-header__title {
    font-size: var(--ar-font-size-display);
    color: var(--ar-color-light);
}

.ar-page-header__sub {
    font-size: var(--ar-font-size-lg);
    color: var(--ar-color-grey);
    max-width: 600px;
    margin-top: var(--ar-spacing-md);
}

/* ============================================
   PROCESS STEPS
   ============================================ */
.ar-process {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--ar-spacing-lg);
    counter-reset: process;
}

.ar-process__step {
    position: relative;
    padding-top: var(--ar-spacing-xl);
}

.ar-process__step::before {
    content: counter(process, decimal-leading-zero);
    counter-increment: process;
    font-family: var(--ar-font-accent);
    font-size: var(--ar-font-size-3xl);
    color: var(--ar-color-accent);
    opacity: 0.3;
    position: absolute;
    top: 0;
    left: 0;
}

.ar-process__title {
    font-family: var(--ar-font-heading);
    font-size: var(--ar-font-size-lg);
    margin-bottom: var(--ar-spacing-xs);
}

.ar-process__desc {
    font-size: var(--ar-font-size-sm);
    color: var(--ar-color-text-light);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
    .ar-portfolio { grid-template-columns: 1fr; }
    .ar-services { grid-template-columns: 1fr; }
    .ar-footer__inner { grid-template-columns: 1fr; gap: var(--ar-spacing-lg); }
    .ar-about-bio { grid-template-columns: 1fr; }
    .ar-contact-grid { grid-template-columns: 1fr; }
    .ar-project-meta { grid-template-columns: repeat(2, 1fr); }
    .ar-process { grid-template-columns: repeat(2, 1fr); }
    .ar-blog-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .ar-nav { display: none; }
    .ar-menu-toggle { display: flex; }
    .ar-hero { padding: var(--ar-spacing-xl) var(--ar-spacing-md); }
    .ar-process { grid-template-columns: 1fr; }
    .ar-project-meta { grid-template-columns: 1fr; }
    .ar-project-gallery { grid-template-columns: 1fr; }

    .ar-portfolio--numbered .ar-portfolio__item {
        grid-template-columns: 60px 1fr;
    }
}

/* ============================================
   ELEMENTOR OVERRIDES & COMPATIBILITY
   ============================================ */
.elementor-page .ar-header {
    z-index: 10000;
}

.elementor-section.elementor-section-full_width > .elementor-container {
    max-width: 100%;
}

/* Elementor Flex container support */
.e-con {
    --container-max-width: var(--ar-container-max);
}

/* Override Elementor default widget spacing */
.elementor-widget:not(:last-child) {
    margin-bottom: var(--ar-spacing-md);
}

/* Ensure theme animations work within Elementor */
.elementor-element .ar-reveal,
.elementor-element .ar-stagger {
    opacity: 0;
}

.elementor-element .ar-reveal.visible,
.elementor-element .ar-stagger.visible > * {
    opacity: 1;
}

/* Custom Elementor Section Styles */
.elementor-section[data-ar-dark="true"] {
    background-color: var(--ar-color-dark) !important;
    color: var(--ar-color-light);
}

/* Smooth scrollbar compatibility */
body.ar-smooth-scroll {
    scroll-behavior: smooth;
}
