/* ==========================================================================
   Cartally Theme - Main Stylesheet
   ========================================================================== */

/* ---------- CSS Custom Properties ---------- */
:root {
    /* ---- Brand Colors ---- */
    --color-primary:        #ffff81;  /* Yellow – main CTA, highlights */
    --color-primary-hover:  #e8e84a;
    --color-primary-fg:     #18181b;  /* Text on primary (dark on yellow) */
    --color-accent:         #7377e7;  /* Purple – links, icons, secondary text */
    --color-accent-hover:   #5c60d4;
    --color-accent-fg:      #ffffff;

    /* ---- Backgrounds ---- */
    --color-bg:             #fefeff;  /* Main page background */
    --color-bg-alt:         #f9f9fd;  /* Alternate sections */
    --color-bg-muted:       #f3f3f7;  /* Slightly darker sections */
    --color-bg-dark:        #2f3034;  /* Dark sections */
    --color-bg-darkest:     #18181b;  /* Footer, navbar dark */
    --color-white:          #ffffff;
    --color-bg-1:           #fffdf6;

    /* ---- Text ---- */
    --color-text:           #18181b;
    --color-text-muted:     #6b7280;
    --color-text-on-dark:   #f3f3f7;
    --color-text-on-dark-muted: #9ca3af;

    /* ---- Borders ---- */
    --color-border:         #e8e8f0;
    --color-border-dark:    rgba(255, 255, 255, 0.1);

    /* Backward‑compat aliases */
    --color-secondary:      var(--color-bg-darkest);
    --color-text-light:     var(--color-text-muted);

    /* ---- Typography ---- */
    --font-sans: 'Satoshi', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-mono: 'SF Mono', 'Fira Code', 'Fira Mono', 'Roboto Mono', monospace;

    --font-light:    300;
    --font-regular:  400;
    --font-medium:   500;
    --font-semibold: 600;
    --font-bold:     700;
    --font-black:    900;

    /* Type Scale */
    --text-xs:   0.75rem;    /* 12px */
    --text-sm:   0.875rem;   /* 14px */
    --text-base: 1rem;       /* 16px */
    --text-md:   1.125rem;   /* 18px */
    --text-lg:   1.25rem;    /* 20px */
    --text-xl:   1.5rem;     /* 24px */
    --text-2xl:  2rem;       /* 32px */
    --text-3xl:  2.5rem;     /* 40px */
    --text-4xl:  3.5rem;     /* 56px */
    --text-hero: clamp(3rem, 7vw, 5rem);

    /* Line Heights */
    --leading-tight:   1.2;
    --leading-snug:    1.4;
    --leading-normal:  1.65;
    --leading-relaxed: 1.8;

    /* ---- Layout ---- */
    --container-width: 1200px;
    --container-wide:  1400px;

    /* ---- Spacing ---- */
    --spacing-1:  0.25rem;
    --spacing-2:  0.5rem;
    --spacing-3:  0.75rem;
    --spacing-4:  1rem;
    --spacing-6:  1.5rem;
    --spacing-8:  2rem;
    --spacing-12: 3rem;
    --spacing-16: 4rem;
    --spacing-20: 5rem;
    --spacing-24: 6rem;

    /* Aliases */
    --spacing-xs:  var(--spacing-1);
    --spacing-sm:  var(--spacing-2);
    --spacing-md:  var(--spacing-4);
    --spacing-lg:  var(--spacing-8);
    --spacing-xl:  var(--spacing-12);
    --spacing-2xl: var(--spacing-20);

    /* ---- Border Radius ---- */
    --radius-sm:   6px;
    --radius:      8px;
    --radius-lg:   16px;
    --radius-xl:   24px;
    --radius-full: 9999px;

    /* ---- Shadows ---- */
    --shadow-xs:      0 1px 2px rgba(0,0,0,0.04);
    --shadow-sm:      0 2px 4px rgba(0,0,0,0.06);
    --shadow-md:      0 4px 16px rgba(0,0,0,0.08);
    --shadow-lg:      0 8px 32px rgba(0,0,0,0.12);
    --shadow-xl:      0 16px 48px rgba(0,0,0,0.16);
    --shadow-primary: 0 4px 20px rgba(255, 255, 129, 0.35);
    --shadow-accent:  0 4px 20px rgba(115, 119, 231, 0.28);

    /* ---- Transitions ---- */
    --transition:      0.2s ease;
    --transition-slow: 0.4s ease;
}

/* ---------- Reset & Base ---------- */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--text-base);
    font-weight: var(--font-regular);
    line-height: var(--leading-normal);
    color: var(--color-text);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

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

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

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

/* ---------- Accessibility ---------- */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute !important;
    width: 1px;
    word-wrap: normal !important;
}

.screen-reader-text:focus {
    background-color: var(--color-bg);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    clip: auto !important;
    clip-path: none;
    color: var(--color-secondary);
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}

.skip-link:focus {
    z-index: 100001;
}

/* ---------- Layout ---------- */
.container {
    width: 100%;
    max-width: var(--container-width);
    margin-inline: auto;
    padding-inline: var(--spacing-md);
}

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

.content-area {
    padding-block: var(--spacing-xl);
}

.content-area.has-sidebar {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: var(--spacing-xl);
}

@media (max-width: 768px) {
    .content-area.has-sidebar {
        grid-template-columns: 1fr;
    }
}

/* ---------- Header ---------- */
.site-header {
    background: #fffdf6d1;
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 1000;
    transition: box-shadow var(--transition);
    backdrop-filter: blur(18px);
}

/* .site-header.is-scrolled {
    box-shadow: var(--shadow-md);
} */

.site-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 68px;
    gap: var(--spacing-6);
}

/* Logo */
.site-logo-link {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.site-logo {
    height: 32px;
    width: auto;
    display: block;
}

/* Backward compat for custom_logo */
.site-branding .custom-logo {
    height: 32px;
    width: auto;
    display: block;
}

.site-branding .site-title {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    color: var(--color-text);
    text-decoration: none;
}

/* ---------- Navigation ---------- */
.main-navigation {
    flex: 1;
    display: flex;
    justify-content: center;
}

.main-navigation ul {
    display: flex;
    gap: var(--spacing-1);
    list-style: none;
    margin: 0;
    padding: 0;
    align-items: center;
}

.main-navigation a {
    display: block;
    padding: var(--spacing-2) var(--spacing-3);
    color: var(--color-text);
    font-weight: var(--font-medium);
    font-size: var(--text-base);
    border-radius: var(--radius-sm);
    text-decoration: none;
    position: relative;
    transition: color var(--transition);
}

.main-navigation a::after {
    content: '';
    position: absolute;
    left: var(--spacing-3);
    right: var(--spacing-3);
    bottom: 2px;
    height: 2px;
    background: var(--color-text);
    border-radius: var(--radius-full);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--transition);
}

.main-navigation a:hover {
    color: #111113;
}

.main-navigation a:hover::after,
.main-navigation .current-menu-item > a::after,
.main-navigation .current-page-ancestor > a::after {
    transform: scaleX(1);
}

.main-navigation .current-menu-item > a,
.main-navigation .current-page-ancestor > a {
    color: #111113;
    font-weight: var(--font-semibold);
}

/* Sub-menus */
.main-navigation li {
    position: relative;
}

.main-navigation .sub-menu {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    min-width: 200px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    padding: var(--spacing-2) 0;
    z-index: 200;
    flex-direction: column;
    gap: 0;
}

.main-navigation li:hover > .sub-menu {
    display: flex;
}

.main-navigation .sub-menu a {
    white-space: nowrap;
    border-radius: 0;
    font-size: var(--text-sm);
    padding: var(--spacing-2) var(--spacing-4);
}

.main-navigation .sub-menu a::after {
    display: none;
}

/* ---------- Header CTA ---------- */
.header-cta {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    flex-shrink: 0;
}

.btn.btn-ghost-nav {
    background: transparent;
    color: var(--color-text);
    border: 1.5px solid rgba(24, 24, 27, 0.65);
    padding: 0.38em 1em;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    border-radius: var(--radius);
    transition: border-color var(--transition), color var(--transition), background var(--transition);
    text-decoration: none;
    white-space: nowrap;
}

.btn.btn-ghost-nav:hover {
    border-color: var(--color-text);
    color: var(--color-text);
    background: var(--color-bg-muted);
}

.btn-nav {
    padding: 0.38em 1em;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    white-space: nowrap;
}

/* ---------- Mobile Menu Toggle ---------- */
.menu-toggle {
    display: none;
    background: none;
    border: none;
    padding: var(--spacing-2);
    cursor: pointer;
    flex-shrink: 0;
}

.hamburger-icon {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 24px;
    height: 24px;
}

.hamburger-icon span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--color-text);
    border-radius: var(--radius-full);
    transform-origin: center;
    transition: transform var(--transition), opacity var(--transition);
}

/* Hamburger → X */
.menu-toggle[aria-expanded="true"] .hamburger-icon span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] .hamburger-icon span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}

.menu-toggle[aria-expanded="true"] .hamburger-icon span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* ---------- Mobile Menu Panel ---------- */
.mobile-menu-panel {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    background: transparent;
    z-index: 999;
}

.mobile-menu-panel[hidden] {
    display: none;
}

.mobile-menu-inner {
    margin: var(--spacing-2) var(--spacing-4) var(--spacing-4);
    background: var(--color-bg-dark);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-lg);
    padding: var(--spacing-4);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    box-shadow: var(--shadow-xl);
}

.mobile-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.mobile-navigation a {
    display: block;
    padding: var(--spacing-3) var(--spacing-3);
    color: var(--color-text-on-dark);
    font-weight: var(--font-medium);
    font-size: var(--text-md);
    border-radius: var(--radius);
    text-decoration: none;
    transition: background var(--transition), color var(--transition);
}

.mobile-navigation a:hover,
.mobile-navigation .current-menu-item > a {
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-white);
}

.mobile-navigation .sub-menu {
    list-style: none;
    padding: var(--spacing-1) 0 0 var(--spacing-4);
    margin: 0;
}

.mobile-navigation .sub-menu a {
    font-size: var(--text-sm);
    color: var(--color-text-on-dark-muted);
    padding: var(--spacing-2) var(--spacing-3);
}

.mobile-cta {
    display: flex;
    gap: var(--spacing-2);
    padding-top: var(--spacing-2);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.mobile-cta .btn {
    flex: 1;
    text-align: center;
}

.btn.btn-ghost-nav-dark {
    background: transparent;
    color: var(--color-text-on-dark);
    border: 1.5px solid rgba(255, 255, 255, 0.3);
    padding: 0.45em 1em;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    border-radius: var(--radius);
    transition: border-color var(--transition), background var(--transition);
    text-decoration: none;
    white-space: nowrap;
    display: inline-block;
    text-align: center;
}

.btn.btn-ghost-nav-dark:hover {
    border-color: rgba(255, 255, 255, 0.5);
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-white);
}

/* ---------- Responsive: show/hide ---------- */
@media (max-width: 900px) {
    .main-navigation,
    .header-cta {
        display: none;
    }

    .menu-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

@media (min-width: 901px) {
    .mobile-menu-panel {
        display: none !important;
    }
}

/* ---------- Hero ---------- */
.hero-section {
    background: var(--color-bg-1);
    color: var(--color-text);
    padding: var(--spacing-2xl) 0;
    position: relative;
    overflow: hidden;
}

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

.hero-left {
    max-width: 600px;
}

.hero-title {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 700;
    color: var(--color-secondary);
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-md);
}

.hero-subtitle {
    font-size: var(--text-lg);
    line-height: var(--leading-normal);
    color: var(--color-text-light);
    margin: 0 0 var(--spacing-lg);
}

.hero-buttons {
    display: flex;
    gap: var(--spacing-4);
    align-items: center;
}

.hero-buttons .btn {
    font-size: var(--text-base);
    padding: 0.65em 1.5em;
}

/* Right column - Mockup */
.hero-right {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.hero-mockup {
    position: relative;
    width: 80%;
    margin: 0 auto;
    max-width: 500px;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
    background: var(--color-bg-alt);
}

.highlight-text {
    background: var(--color-primary);
    color: var(--color-primary-fg);
    padding: 0.1em 0.3em;
    border-radius: var(--radius);
    display: inline-block;
    transition: opacity 0.3s ease;
    margin-top: 0.1em;
}

.mockup-person {
    width: 80%;
    height: auto;
    display: block;
    aspect-ratio: 4/5;
    object-fit: cover;
}

/* UI Overlay styling */
.mockup-ui-overlay {
    position: absolute;
    bottom: var(--spacing-md);
    left: var(--spacing-md);
    right: var(--spacing-md);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.mockup-search-bar {
    background: var(--color-white);
    border-radius: var(--radius);
    padding: var(--spacing-3) var(--spacing-4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--color-border);
}

.mockup-search-inner {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    flex: 1;
    min-width: 0;
}

.mockup-search-inner .search-icon {
    color: var(--color-text-muted);
    font-size: 20px;
    flex-shrink: 0;
}

.mockup-input-scroll {
    display: flex;
    align-items: center;
    flex: 1;
    overflow-x: hidden;
    white-space: nowrap;
    min-width: 0;
}

.mockup-typing-text {
    font-size: var(--text-sm);
    color: var(--color-text);
    font-weight: var(--font-medium);
    white-space: nowrap;
}

.mockup-cursor {
    display: inline-block;
    width: 2px;
    height: 1.2em;
    background-color: var(--color-text);
    animation: blink 1s step-end infinite;
    flex-shrink: 0;
    margin-left: 2px;
}

.mockup-ai-badge {
    display: flex;
    align-items: center;
    gap: 4px;
    background: var(--color-accent);
    color: var(--color-accent-fg);
    padding: 4px 10px;
    border-radius: var(--radius);
    font-size: 0.85rem;
    font-weight: var(--font-bold);
    letter-spacing: 0.05em;
    box-shadow: var(--shadow-sm);
    flex-shrink: 0;
}

.mockup-ai-badge .material-symbols-rounded {
    font-size: 14px;
}

.mockup-results {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.mockup-results.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.mockup-result {
    background: var(--color-white);
    border-radius: var(--radius);
    padding: var(--spacing-sm);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-border);
    animation: popIn 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
    opacity: 0;
}

.mockup-result:nth-child(1) { animation-delay: 0.1s; }
.mockup-result:nth-child(2) { animation-delay: 0.2s; }
.mockup-result:nth-child(3) { animation-delay: 0.3s; }

.mockup-result img {
    width: 100%;
    aspect-ratio: 1/1;
    object-fit: contain;
    border-radius: var(--radius-sm);
}

@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

@keyframes popIn {
    0% { opacity: 0; transform: scale(0.9); }
    100% { opacity: 1; transform: scale(1); }
}

/* Responsive Hero */
@media (max-width: 767px) {
    .hero-section {
        padding-top: var(--spacing-6);
    }
}

@media (max-width: 900px) {
    .hero-container {
        grid-template-columns: 1fr;
        text-align: left;
    }

    .hero-left {
        max-width: 100%;
        margin: 0;
    }

    .hero-buttons {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .hero-mockup {
        width: 90%;
    }
}

/* ---------- About Hero Section ---------- */
.about-hero-section {
    background: var(--color-bg-1);
    padding: var(--spacing-2xl) 0;
    color: var(--color-text);
}

.about-hero-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    align-items: center;
}

.about-image-wrapper {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.about-img {
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 4/3;
    object-fit: cover;
}

.about-overlay-bar {
    position: absolute;
    bottom: var(--spacing-md);
    left: var(--spacing-md);
    right: var(--spacing-md);
    background: var(--color-white);
    border-radius: var(--radius);
    padding: var(--spacing-3) var(--spacing-4);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-border);
}

.overlay-status {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.status-dot {
    width: 8px;
    height: 8px;
    background: #22c55e;
    border-radius: 50%;
    display: inline-block;
    box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.2);
    animation: pulse-dot 2s infinite;
}

.status-text {
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: var(--font-bold);
    color: var(--color-text-muted);
}

.overlay-query {
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-text);
}

.about-hero-right .section-kicker {
    display: block;
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: var(--font-bold);
    color: var(--color-accent);
    margin-bottom: var(--spacing-2);
}

.about-hero-right .section-heading {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: var(--font-bold);
    color: var(--color-secondary);
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-md);
}

.about-hero-right .section-description {
    font-size: var(--text-lg);
    line-height: var(--leading-normal);
    color: var(--color-text-light);
    margin: 0 0 var(--spacing-lg);
}

@keyframes pulse-dot {
    0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.7); }
    70% { transform: scale(1); box-shadow: 0 0 0 6px rgba(34, 197, 94, 0); }
    100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(34, 197, 94, 0); }
}

@media (max-width: 900px) {
    .about-hero-container {
        grid-template-columns: 1fr;
    }
    
    .about-hero-left {
        order: 2;
    }
    
    .about-hero-right {
        order: 1;
        text-align: left;
    }
}

/* ---------- Conversion Teaser Section ---------- */
.conv-teaser-section {
    padding: var(--spacing-8) 0;
    background: var(--color-bg);
}

.conv-teaser-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-16);
    background: var(--color-bg-darkest);
    border-radius: var(--radius-xl);
    padding: var(--spacing-8) var(--spacing-12);
    overflow: hidden;
    position: relative;
}

/* Decorative glow behind the stat */
.conv-teaser-card::before {
    content: '';
    position: absolute;
    top: -60px;
    left: -60px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(115,119,231,0.25) 0%, transparent 70%);
    pointer-events: none;
}

.conv-teaser-stat {
    flex-shrink: 0;
    font-family: var(--font-sans);
    font-size: clamp(5rem, 10vw, 8rem);
    font-weight: var(--font-black);
    color: var(--color-primary);
    line-height: 1;
    letter-spacing: -0.04em;
}

.conv-teaser-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

.conv-teaser-heading {
    font-family: var(--font-sans);
    font-size: clamp(1.5rem, 3vw, var(--text-2xl));
    font-weight: var(--font-bold);
    color: var(--color-text-on-dark);
    line-height: var(--leading-tight);
    letter-spacing: -0.02em;
    margin: 0;
}

.conv-teaser-body {
    font-size: var(--text-md);
    line-height: var(--leading-normal);
    color: var(--color-text-on-dark-muted);
    margin: 0;
    max-width: 560px;
}

@media (max-width: 767px) {
    .conv-teaser-card {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: var(--spacing-4);
        padding: var(--spacing-8) var(--spacing-8);
    }

    .conv-teaser-stat {
        font-size: clamp(5rem, 22vw, 7rem);
    }

    .conv-teaser-body {
        font-size: var(--text-sm);
        max-width: none;
    }
}

/* ---------- How it works Section ---------- */
.how-it-works-section {
    padding: var(--spacing-2xl) 0;
    background: var(--color-bg-1);
}

.hiw-header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto var(--spacing-xl);
}

.hiw-heading {
    font-size: clamp(2.5rem, 5vw, 4rem);
    color: var(--color-secondary);
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-md);
}

.hiw-subtitle {
    font-size: var(--text-lg);
    line-height: var(--leading-normal);
    color: var(--color-text-light);
    margin: 0;
}

.hiw-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-xl);
}

.hiw-step {
    position: relative;
    padding-right: var(--spacing-lg);
}

/* Vertical line separators exclusively on web */
.hiw-step:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 5%;
    bottom: 5%;
    width: 1px;
    background: var(--color-border);
}

.hiw-number {
    font-size: clamp(3rem, 5vw, 4rem);
    font-weight: var(--font-black);
    color: var(--color-accent);
    opacity: 0.15;
    line-height: 1;
    margin-bottom: var(--spacing-2);
}

.hiw-title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--color-secondary);
    margin: 0 0 var(--spacing-sm);
    line-height: var(--leading-snug);
}

.hiw-desc {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text-muted);
    margin: 0;
}

@media (max-width: 900px) {
    .hiw-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-xl);
    }
    
    .hiw-step {
        padding-right: 0;
    }
    
    .hiw-step:not(:last-child)::after {
        display: none;
    }
    
    .hiw-header {
        text-align: left;
    }
}

/* ---------- CMS Slider Section ---------- */
.cms-slider-section {
    padding: var(--spacing-xl) 0;
    background: var(--color-bg-1);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    padding-bottom: 120px !important;
    /* max-width: var(--container-width, 1200px);
    margin: 0 auto;
    width: 100%; */
}

.cms-slider-header {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xs); /* Delikatny dodatkowy odstęp w razie potrzeby, ale flex gap w sekcji zrobi główne tło */
}

.cms-slider-subtitle {
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.cms-slider-title {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: var(--font-bold);
    color: var(--color-secondary);
    margin: 0;
    line-height: var(--leading-tight);
}

.api-separator {
    font-size: 0.8rem;
    font-weight: 700;
    color: #111;
    text-transform: uppercase;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #d1d5db; /* gray */
    padding: 0.2rem 0.6rem;
    border-radius: 4px;
    opacity: 1;
    height: fit-content;
    transition: all 0.3s ease;
}

.api-separator:hover {
    transform: scale(1.05);
    background: var(--color-primary);
}

.cms-slider {
    position: relative;
    width: 100%;
    /* Masking for the edges - fade out effect */
    -webkit-mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent);
    mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent);
}

.cms-slide-track {
    display: flex;
    width: max-content;
}

.cms-logo-group {
    display: flex;
    align-items: center;
    gap: var(--spacing-2xl);
    padding-right: var(--spacing-2xl); /* crucial for seamless loop */
}

/* Base speed for scrolling */
.track-left {
    animation: scroll-left 80s linear infinite;
}

.track-right {
    /* For right scroll, we start at -50% and go to 0 */
    transform: translateX(-50%);
    animation: scroll-right 80s linear infinite;
}

/* Pause on hover */
.cms-slider:hover .cms-slide-track {
    animation-play-state: paused;
}

@keyframes scroll-left {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

@keyframes scroll-right {
    from { transform: translateX(-50%); }
    to { transform: translateX(0); }
}

.cms-logo-slide {
    width: 120px;
    height: 45px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cms-logo-slide img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    filter: grayscale(100%);
    transition: all 0.3s ease;
}

.cms-logo-slide img:hover {
    transform: scale(1.05);
    filter: grayscale(0%);
}

@media (max-width: 768px) {
    .cms-slider {
        -webkit-mask-image: linear-gradient(to right, transparent, black 5%, black 95%, transparent);
        mask-image: linear-gradient(to right, transparent, black 5%, black 95%, transparent);
    }
    
    .cms-logo-slide {
        width: 90px;
        height: 35px;
    }
    
    .cms-logo-group {
        gap: var(--spacing-lg);
        padding-right: var(--spacing-lg);
    }
}

/* ---------- Features Grid Section ---------- */
.features-section {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
    padding: var(--spacing-2xl) var(--spacing-xl);
    border-radius: 64px 64px 0 0;
    /* margin-top: var(--spacing-2xl); */
}

.features-container {
    max-width: var(--container-width);
    margin: 0 auto;
}

.features-title {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: var(--font-bold);
    color: var(--color-white);
    margin: 0 0 calc(var(--spacing-xl) + var(--spacing-md));
    max-width: 600px;
    line-height: var(--leading-tight);
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
}

.feature-card {
    background: var(--color-bg-dark);
    border-radius: 20px;
    padding: var(--spacing-xl) var(--spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    position: relative;
    overflow: hidden;
}

.feature-card-title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--color-white);
    margin: 0 0 var(--spacing-xs);
    line-height: var(--leading-snug);
}

.feature-card-desc {
    font-size: var(--text-base);
    color: var(--color-text-on-dark-muted);
    margin: 0;
    line-height: var(--leading-relaxed);
}

/* Row 1 / Large Card */
.feature-card--large {
    grid-column: span 2;
    flex-direction: row;
    align-items: stretch;
    padding: 0; 
    position: relative;
    overflow: hidden;
}

.feature-card--large .feature-card-content {
    padding: var(--spacing-lg) var(--spacing-xl);
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--spacing-md);
    z-index: 2;
}

.feature-text {
    margin-top: 0;
    margin-bottom: var(--spacing-sm);
}

.feature-card--large .feature-card-deco {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 40%;
    background: linear-gradient(270deg, rgba(255,255,255,0.03) 0%, transparent 100%);
    pointer-events: none;
    z-index: 1;
}

.feature-card--large .feature-card-deco::after {
    content: '';
    position: absolute;
    top: 50%;
    right: -20%;
    transform: translateY(-50%);
    width: 300px;
    height: 300px;
    background: var(--color-accent);
    filter: blur(80px);
    opacity: 0.15;
    border-radius: 50%;
}

.feature-card--large .feature-icon .material-symbols-rounded {
    font-size: 32px;
    color: var(--color-accent);
}

/* Row 1 / Accent Card */
.feature-card--accent {
    background: var(--color-primary);
    color: var(--color-primary-fg);
    justify-content: center;
    padding: var(--spacing-lg) var(--spacing-lg);
}

.feature-card--accent .feature-card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--spacing-xs);
}

.feature-card--accent .feature-card-title,
.feature-card--accent .feature-card-desc {
    color: var(--color-primary-fg);
}

.feature-card--accent .feature-card-desc {
    opacity: 0.85;
}

.feature-icon-bottom {
    display: flex;
    justify-content: flex-end;
    margin-top: var(--spacing-sm);
}

.feature-icon-bottom .material-symbols-rounded {
    font-size: 56px;
    opacity: 0.15;
}

/* Row 2 */
.feature-card:not(.feature-card--large):not(.feature-card--accent) {
    justify-content: space-between;
}

@media (max-width: 900px) {
    .features-grid {
        grid-template-columns: 1fr;
    }
    
    .feature-card--large {
        grid-column: span 1;
        flex-direction: column;
    }

    .feature-card--large .feature-card-content {
        padding-bottom: var(--spacing-xl);
    }
    
    .feature-card--large .feature-card-deco {
        position: absolute;
        top: auto;
        bottom: 0;
        right: 0;
        left: 0;
        width: 100%;
        height: 60%;
        background: linear-gradient(0deg, rgba(255,255,255,0.03) 0%, transparent 100%);
    }

    .feature-card--large .feature-card-deco::after {
        top: auto;
        bottom: -20%;
        right: 50%;
        transform: translateX(50%);
    }
    
    .features-section {
        border-radius: 40px 40px 0 0;
        padding: var(--spacing-xl) var(--spacing-md);
    }
}

/* ---------- Choose Option Section ---------- */
.choose-option-section {
    padding: var(--spacing-2xl) 0;
    background: var(--color-bg-1);
}

.choose-header {
    text-align: left;
    max-width: 800px;
    margin: 0 0 calc(var(--spacing-xl) + var(--spacing-md));
}

.choose-heading {
    font-size: clamp(2.5rem, 5vw, 4rem);
    color: var(--color-secondary);
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-md);
    font-weight: var(--font-bold);
}

.choose-subtitle {
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--color-text-light);
    margin: 0;
}

.choose-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    max-width: 850px;
    margin: 0 auto;
}

.choose-card {
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg) var(--spacing-lg);
    display: flex;
    flex-direction: column;
    text-align: left;
    align-items: flex-start;
    background: var(--color-bg-dark);
    position: relative;
    overflow: hidden;
}

.choose-card-badge {
    position: absolute !important;
    top: var(--spacing-lg);
    right: var(--spacing-lg);
    background: transparent;
    border: 1px solid var(--color-primary);
    color: var(--color-primary);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.25rem 0.5rem;
    border-radius: calc(var(--radius) - 2px);
    z-index: 10;
}

.choose-card--other .choose-card-badge {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.choose-card > div:not(.choose-card-deco):not(.choose-card-badge) {
    position: relative;
    z-index: 2;
}

.choose-card-deco {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 60%;
    background: linear-gradient(270deg, rgba(255,255,255,0.03) 0%, transparent 100%);
    pointer-events: none;
    z-index: 1;
}

.choose-card-deco::after {
    content: '';
    position: absolute;
    bottom: -20%;
    right: -20%;
    width: 250px;
    height: 250px;
    background: var(--color-accent);
    filter: blur(80px);
    opacity: 0.15;
    border-radius: 50%;
}

.choose-card--shopify .choose-card-deco::after {
    background: var(--color-primary);
}

.choose-card-icon {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: var(--spacing-md);
    width: 100%;
}

.choose-card-icon .material-symbols-rounded {
    font-size: 40px;
}

.choose-card--shopify .choose-card-icon .material-symbols-rounded {
    color: var(--color-primary);
}

.choose-card--other .choose-card-icon .material-symbols-rounded {
    color: var(--color-accent);
}
.choose-card-content {
    flex: 1;
    margin-bottom: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.choose-card-title {
    font-size: var(--text-2xl);
    color: var(--color-white);
    margin: 0;
    font-weight: var(--font-bold);
    line-height: var(--leading-tight);
}

.choose-card-desc {
    font-size: var(--text-base);
    color: var(--color-text-on-dark-muted);
    line-height: var(--leading-relaxed);
    margin: 0;
}

.choose-card-footer {
    width: 100%;
    display: flex;
    justify-content: center;
}

.choose-btn {
    width: 80%;
    padding: 0.75em 1em !important;
    font-size: var(--text-base);
    border-radius: var(--radius-xl);
    text-align: center;
}

@media (max-width: 900px) {
    .choose-grid {
        grid-template-columns: 1fr;
    }
    
    .choose-btn {
        width: 100%;
    }
}

/* ---------- Live Demo Section ---------- */
.live-demo-section {
    padding: var(--spacing-xl) 0 var(--spacing-2xl);
    background: var(--color-bg-1);
}

.live-demo-banner {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl) var(--spacing-2xl);
    text-align: left;
    box-shadow: var(--shadow-xl);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-xl);
}

.live-demo-banner::before {
    content: '';
    position: absolute;
    top: -50%;
    left: 0;
    width: 300px;
    height: 300px;
    background: var(--color-accent);
    filter: blur(140px);
    opacity: 0.15;
    pointer-events: none;
    border-radius: 50%;
}

.live-demo-banner::after {
    content: '';
    position: absolute;
    bottom: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: var(--color-primary);
    filter: blur(120px);
    opacity: 0.1;
    pointer-events: none;
    border-radius: 50%;
}

.live-demo-banner > * {
    position: relative;
    z-index: 2;
}

.demo-content {
    flex: 1;
    max-width: 600px;
}

.demo-kicker {
    display: inline-block;
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: var(--font-bold);
    color: var(--color-accent);
    margin-bottom: var(--spacing-2);
}

.demo-heading {
    font-size: clamp(2rem, 4vw, 2.5rem);
    font-weight: var(--font-bold);
    color: var(--color-white);
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-sm);
}

.demo-description {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text-on-dark-muted);
    margin: 0;
}

.demo-action {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.live-demo-btn {
    padding: 0.85em 2em !important;
    font-size: var(--text-lg);
    border-radius: var(--radius-xl);
    display: inline-flex !important;
    justify-content: center;
    white-space: nowrap;
}

@media (max-width: 900px) {
    .live-demo-banner {
        flex-direction: column;
        align-items: flex-start;
        padding: var(--spacing-xl) var(--spacing-lg);
    }
    
    .demo-action, .live-demo-btn {
        width: 100%;
    }
}

/* ---------- Buttons ---------- */
.btn {
    display: inline-block;
    padding: 0.45em 1.25em;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    border-radius: var(--radius);
    border: 2px solid transparent;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);
    text-align: center;
    line-height: 1.5;
}

.btn-icon {
    display: inline-flex !important;
    align-items: center;
    gap: var(--spacing-2);
}

.btn-icon .material-symbols-rounded {
    font-size: 20px;
}

.btn-primary {
    background: var(--color-primary);
    color: var(--color-primary-fg);
    border-color: var(--color-primary);
    box-shadow: var(--shadow-primary);
}

.btn-primary:hover {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-primary-fg);
    box-shadow: none;
}

.btn-accent {
    background: var(--color-accent);
    color: var(--color-accent-fg);
    border-color: var(--color-accent);
    box-shadow: 0 4px 14px 0 rgba(115,119,231,0.39);
}

.btn-accent:hover {
    background: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    color: var(--color-accent-fg);
    box-shadow: none;
}

.btn-outline {
    background: transparent;
    color: var(--color-accent);
    border-color: var(--color-accent);
}

.btn-outline:hover {
    background: var(--color-accent);
    color: var(--color-accent-fg);
    box-shadow: var(--shadow-accent);
}

.btn-dark {
    background: var(--color-secondary);
    color: var(--color-white);
    border-color: var(--color-secondary);
}

.btn-dark:hover {
    background: var(--color-bg-dark);
    border-color: var(--color-bg-dark);
    color: var(--color-white);
}

.btn-shopify {
    background: #9fbf58;
    color: #ffffff;
    border-color: #9fbf58;
}

.btn-shopify:hover {
    background: #8fae4e;
    border-color: #8fae4e;
    color: #ffffff;
}

/* ---------- Sections ---------- */
.page-content-section,
.latest-posts-section {
    padding: var(--spacing-2xl) 0;
}

.latest-posts-section {
    background: var(--color-bg-alt);
}

.section-title {
    text-align: center;
    font-size: 2rem;
    color: var(--color-secondary);
    margin: 0 0 var(--spacing-xl);
}

.section-cta {
    text-align: center;
    margin-top: var(--spacing-xl);
}

/* ---------- Posts Grid ---------- */
.posts-grid {
    display: grid;
    gap: var(--spacing-lg);
}

.posts-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 1024px) {
    .posts-grid--3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .posts-grid--3 {
        grid-template-columns: 1fr;
    }
}

/* ---------- Post Card ---------- */
.post-card {
    background: var(--color-white);
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--color-border);
    transition: box-shadow var(--transition), transform var(--transition);
}

.post-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

.post-card .post-thumbnail img {
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
}

.post-card-content {
    padding: var(--spacing-lg);
}

.post-card .entry-title {
    font-size: 1.25rem;
    margin: 0 0 var(--spacing-sm);
    line-height: 1.4;
}

.post-card .entry-title a {
    color: var(--color-secondary);
}

.post-card .entry-title a:hover {
    color: var(--color-primary);
}

.post-card .entry-meta {
    font-size: 0.8125rem;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-md);
}

.post-card .entry-summary p {
    margin: 0;
    color: var(--color-text-light);
    font-size: 0.9375rem;
}

.read-more {
    display: inline-block;
    margin-top: var(--spacing-md);
    font-weight: 600;
    font-size: 0.875rem;
}

/* ---------- Single Post — Medium-style Article ---------- */

/* Background for single article pages */
.site-main--article {
    background: var(--color-bg-1);
}

/* Container: narrow reading column */
.article-container {
    max-width: 780px;
    margin: 0 auto;
    padding: var(--spacing-16) var(--spacing-md) var(--spacing-24);
}

/* When used as archive/blog listing, widen the container */
.article-container > .posts-block {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
    border-top: none;
}

/* ---- Header ---- */
.article-header {
    margin-bottom: 0;
    text-align: left;
}

.article-category a {
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-accent);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: var(--spacing-6);
    transition: color var(--transition);
}

.article-category a:hover {
    color: var(--color-accent-hover);
}

.article-title {
    font-family: var(--font-sans);
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: var(--font-bold);
    color: var(--color-text);
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-6);
    letter-spacing: -0.02em;
}

.article-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.article-meta-sep {
    opacity: 0.4;
}

/* Share button */
.article-share-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1);
    background: none;
    border: none;
    padding: 0;
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    cursor: pointer;
    transition: color var(--transition);
}

.article-share-btn .material-symbols-rounded {
    font-size: 16px;
}

.article-share-btn:hover {
    color: var(--color-accent);
}

/* ---- Hero Image ---- */
.article-hero {
    margin: 0 0 var(--spacing-12);
}

.article-hero-img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

/* ---- Article Body (the_content) ---- */
.article-body {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
    color: var(--color-text);
}

/* Paragraphs */
.article-body p {
    margin: 0 0 var(--spacing-8);
}

/* Lead: first paragraph */
.article-body > p:first-of-type {
    font-size: var(--text-xl);
    line-height: var(--leading-normal);
    color: var(--color-text);
}

/* Headings */
.article-body h2 {
    font-family: var(--font-sans);
    font-size: clamp(1.5rem, 3vw, var(--text-2xl));
    font-weight: var(--font-bold);
    color: var(--color-text);
    line-height: var(--leading-tight);
    margin: var(--spacing-16) 0 var(--spacing-6);
    letter-spacing: -0.015em;
}

.article-body h3 {
    font-family: var(--font-sans);
    font-size: clamp(1.25rem, 2.5vw, var(--text-xl));
    font-weight: var(--font-semibold);
    color: var(--color-text);
    line-height: var(--leading-snug);
    margin: var(--spacing-12) 0 var(--spacing-4);
}

.article-body h4 {
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: var(--font-semibold);
    color: var(--color-text);
    line-height: var(--leading-snug);
    margin: var(--spacing-8) 0 var(--spacing-4);
}

/* Links */
.article-body a {
    color: var(--color-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: color var(--transition);
}

.article-body a:hover {
    color: var(--color-accent-hover);
}

.article-body a:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
    border-radius: 2px;
}

/* Lists */
.article-body ul,
.article-body ol {
    margin: 0 0 var(--spacing-8);
    padding-left: var(--spacing-8);
}

.article-body li {
    margin-bottom: var(--spacing-2);
    line-height: var(--leading-relaxed);
}

.article-body li::marker {
    color: var(--color-text-muted);
}

/* Blockquote */
.article-body blockquote {
    margin: var(--spacing-12) 0;
    padding: var(--spacing-8) var(--spacing-8);
    border-left: 3px solid var(--color-accent);
    background: transparent;
    font-size: var(--text-xl);
    font-style: italic;
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
}

.article-body blockquote p {
    margin: 0;
}

.article-body blockquote cite {
    display: block;
    margin-top: var(--spacing-4);
    font-size: var(--text-sm);
    font-style: normal;
    color: var(--color-text-muted);
}

/* Images in content */
.article-body img {
    display: block;
    max-width: 100%;
    height: auto;
    border-radius: var(--radius);
    margin: var(--spacing-8) 0;
}

.article-body figure {
    margin: var(--spacing-12) 0;
}

.article-body figure img {
    margin: 0;
}

.article-body figcaption {
    margin-top: var(--spacing-3);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    text-align: center;
    line-height: var(--leading-normal);
}

/* Code — inline */
.article-body code {
    font-family: var(--font-mono);
    font-size: 0.875em;
    background: var(--color-bg-muted);
    padding: 0.15em 0.45em;
    border-radius: var(--radius-sm);
    color: var(--color-text);
}

/* Code — block */
.article-body pre {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
    padding: var(--spacing-8);
    border-radius: var(--radius);
    overflow-x: auto;
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    line-height: 1.7;
    margin: var(--spacing-12) 0;
    -webkit-overflow-scrolling: touch;
}

.article-body pre code {
    background: none;
    padding: 0;
    border-radius: 0;
    font-size: inherit;
    color: inherit;
}

/* Horizontal rule / separator */
.article-body hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--spacing-16) auto;
    max-width: 100px;
}

/* Tables */
.article-body table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--spacing-8) 0;
    font-size: var(--text-base);
}

.article-body th,
.article-body td {
    padding: var(--spacing-3) var(--spacing-4);
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}

.article-body th {
    font-weight: var(--font-semibold);
    color: var(--color-text);
}

/* WP embeds / iframes */
.article-body iframe,
.article-body .wp-block-embed {
    max-width: 100%;
    margin: var(--spacing-12) 0;
}

/* ---- Tags ---- */
.article-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    margin-top: var(--spacing-16);
    padding-top: var(--spacing-8);
    border-top: 1px solid var(--color-border);
}

.article-tag {
    display: inline-block;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    background: var(--color-bg-muted);
    padding: var(--spacing-1) var(--spacing-4);
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: background var(--transition), color var(--transition);
}

.article-tag:hover {
    background: var(--color-bg-dark);
    color: var(--color-text-on-dark);
}

/* ---- Post Navigation (inside article-container) ---- */
.article-container .post-navigation {
    margin-top: var(--spacing-16);
    padding: var(--spacing-8) 0;
    border-top: 1px solid var(--color-border);
}

.article-container .post-navigation .nav-links {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-8);
}

.article-container .nav-subtitle {
    display: block;
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-1);
    font-weight: var(--font-medium);
}

.article-container .nav-title {
    font-weight: var(--font-semibold);
    font-size: var(--text-base);
    color: var(--color-text);
    transition: color var(--transition);
}

.article-container .post-navigation a:hover .nav-title {
    color: var(--color-accent);
}

.article-container .nav-next {
    text-align: right;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
    .article-container {
        padding: var(--spacing-8) var(--spacing-md) var(--spacing-16);
    }

    .article-title {
        font-size: clamp(1.75rem, 6vw, 2.25rem);
    }

    .article-hero-img {
        border-radius: var(--radius);
    }

    .article-body {
        font-size: var(--text-base);
    }

    .article-body > p:first-of-type {
        font-size: var(--text-lg);
    }

    .article-body h2 {
        font-size: var(--text-xl);
        margin-top: var(--spacing-12);
    }

    .article-body h3 {
        font-size: var(--text-lg);
        margin-top: var(--spacing-8);
    }

    .article-body blockquote {
        font-size: var(--text-lg);
        padding: var(--spacing-4) var(--spacing-6);
        margin: var(--spacing-8) 0;
    }

    .article-body pre {
        padding: var(--spacing-4);
        font-size: var(--text-xs);
        border-radius: var(--radius-sm);
        margin: var(--spacing-8) 0;
    }

    .article-container .post-navigation .nav-links {
        grid-template-columns: 1fr;
    }

    .article-container .nav-next {
        text-align: left;
    }
}

/* ---------- Posts Block (reusable grid) ---------- */
.posts-block {
    max-width: 780px;
    margin: 0 auto;
    padding: var(--spacing-8) var(--spacing-md) var(--spacing-12);
    border-top: 1px solid var(--color-border);
}

.posts-block-title {
    font-family: var(--font-sans);
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--color-text);
    margin: 0 0 var(--spacing-8);
    letter-spacing: -0.015em;
}

.posts-block-grid {
    display: grid;
    gap: var(--spacing-12) var(--spacing-8);
}

.posts-block-grid--4,
.posts-block-grid--6 {
    grid-template-columns: repeat(2, 1fr);
}

.posts-block-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--color-text);
    background: transparent;
    transition: opacity var(--transition);
}

.posts-block-card:hover {
    opacity: 0.85;
    color: var(--color-text);
}

.posts-block-thumb {
    overflow: hidden;
    border-radius: var(--radius);
    margin-bottom: var(--spacing-4);
}

.posts-block-img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    transition: transform var(--transition-slow);
}

.posts-block-card:hover .posts-block-img {
    transform: scale(1.03);
}

.posts-block-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
    flex: 1;
}

.posts-block-card-title {
    font-family: var(--font-sans);
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    line-height: var(--leading-snug);
    color: var(--color-text);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.posts-block-excerpt {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.posts-block-date {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-top: auto;
}

/* Pagination */
.posts-block-pagination {
    margin-top: var(--spacing-8);
    display: flex;
    justify-content: center;
    gap: var(--spacing-2);
}

.posts-block-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--spacing-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-weight: var(--font-medium);
    font-size: var(--text-sm);
    color: var(--color-text);
    text-decoration: none;
    transition: background var(--transition), color var(--transition);
}

.posts-block-pagination .page-numbers.current,
.posts-block-pagination .page-numbers:hover {
    background: var(--color-text);
    color: var(--color-white);
    border-color: var(--color-text);
}

@media (max-width: 1024px) {
    .posts-block-grid--4,
    .posts-block-grid--6 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .posts-block-grid--4,
    .posts-block-grid--6 {
        grid-template-columns: 1fr;
    }

    .posts-block {
        padding: var(--spacing-8) var(--spacing-md) var(--spacing-16);
    }
}

/* ---------- Breadcrumbs (Yoast SEO) ---------- */
.breadcrumbs {
    background: var(--color-bg-alt);
    padding: var(--spacing-md) 0;
    font-size: 0.8125rem;
    color: var(--color-text-light);
    border-bottom: 1px solid var(--color-border);
}

.breadcrumbs a {
    color: var(--color-text-light);
}

.breadcrumbs a:hover {
    color: var(--color-primary);
}

/* ---------- Page Header ---------- */
.page-header {
    margin-bottom: var(--spacing-xl);
}

.page-title {
    font-size: 2rem;
    color: var(--color-secondary);
    margin: 0;
}

.archive-description {
    margin-top: var(--spacing-sm);
    color: var(--color-text-light);
}

/* ---------- Sidebar ---------- */
.sidebar {
    font-size: 0.9375rem;
}

.widget {
    margin-bottom: var(--spacing-xl);
}

.widget-title {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-secondary);
    margin: 0 0 var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--color-accent);
}

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

.widget ul li {
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--color-border);
}

.widget ul li:last-child {
    border-bottom: none;
}

/* ---------- Comments ---------- */
.comments-area {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-xl);
    border-top: 1px solid var(--color-border);
}

.comments-title {
    font-size: 1.5rem;
    color: var(--color-secondary);
    margin: 0 0 var(--spacing-lg);
}

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

.comment-list .comment {
    padding: var(--spacing-lg) 0;
    border-bottom: 1px solid var(--color-border);
}

.comment-list .children {
    list-style: none;
    padding-left: var(--spacing-xl);
}

.comment-author .avatar {
    border-radius: 50%;
    float: left;
    margin-right: var(--spacing-md);
}

.comment-content p:last-child {
    margin-bottom: 0;
}

.comment-form textarea,
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"] {
    width: 100%;
    padding: var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-family: var(--font-sans);
    font-size: 1rem;
    transition: border-color var(--transition);
}

.comment-form textarea:focus,
.comment-form input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(115, 119, 231, 0.12);
}

.comment-form .form-submit input {
    background: var(--color-accent);
    color: var(--color-accent-fg);
    border: none;
    padding: 0.75em 2em;
    border-radius: var(--radius);
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    cursor: pointer;
    transition: background var(--transition), box-shadow var(--transition);
}

.comment-form .form-submit input:hover {
    background: var(--color-accent-hover);
    box-shadow: var(--shadow-accent);
}

/* ---------- Pagination ---------- */
.pagination,
.navigation.pagination {
    margin-top: var(--spacing-xl);
    text-align: center;
}

.pagination .nav-links {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm);
}

.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-weight: 500;
    color: var(--color-text);
    transition: background var(--transition), color var(--transition);
}

.pagination .page-numbers.current,
.pagination .page-numbers:hover {
    background: var(--color-accent);
    color: var(--color-white);
    border-color: var(--color-accent);
}

/* ---------- Footer ---------- */
.site-footer {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
}

/* Newsletter block */
.footer-newsletter-wrap {
    padding: var(--spacing-8) 0;
}

.footer-newsletter {
    background: var(--color-primary);
    color: var(--color-primary-fg);
    border-radius: var(--radius-lg);
    padding: var(--spacing-8);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-6);
}

.footer-newsletter-text {
    max-width: 600px;
}

.footer-newsletter-title {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: var(--font-black);
    color: var(--color-primary-fg);
    margin: 0 0 var(--spacing-2);
    line-height: var(--leading-tight);
}

.footer-newsletter-subtitle {
    font-size: var(--text-md);
    font-weight: var(--font-medium);
    color: var(--color-primary-fg);
    opacity: 0.75;
    margin: 0;
    line-height: var(--leading-snug);
}

.footer-newsletter-form {
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
}

/* CF7 inside newsletter */
.footer-newsletter-form .wpcf7-form {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: flex-start;
}

.footer-newsletter-form .wpcf7-form p {
    margin: 0;
}

.footer-newsletter-form .wpcf7-form > p:has(input[type="email"],
.wpcf7-text) {
    flex: 1 1 220px;
}

.footer-newsletter-form .wpcf7-form > p:has(.wpcf7-submit) {
    flex: 0 0 auto;
}

/* Full-width rows: acceptance/checkbox and response */
.footer-newsletter-form .wpcf7-form > p:has(.wpcf7-acceptance),
.footer-newsletter-form .wpcf7-form > p:has(.wpcf7-checkbox),
.footer-newsletter-form .wpcf7-response-output {
    flex: 0 0 100%;
    text-align: left;
}

/* Input field — lighter than primary */
.footer-newsletter-form .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-checkbox):not(.wpcf7-acceptance) {
    background: rgba(255, 255, 255, 0.55);
    border: none;
    color: var(--color-primary-fg);
    border-radius: var(--radius);
    padding: 0.65em 1em;
    font-size: var(--text-base);
    font-family: var(--font-sans);
    width: 100%;
}

.footer-newsletter-form .wpcf7-form-control:not(.wpcf7-submit)::placeholder {
    color: rgba(24, 24, 27, 0.45);
}

.footer-newsletter-form .wpcf7-form-control:not(.wpcf7-submit):focus {
    outline: none;
    border-color: rgba(24, 24, 27, 0.4);
    box-shadow: none;
    background: rgba(255, 255, 255, 0.75);
}

/* Submit button */
.footer-newsletter-form .wpcf7-form-control.wpcf7-submit {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
    border: none;
    border-radius: var(--radius);
    padding: 0.65em 1.75em;
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    cursor: pointer;
    transition: background var(--transition);
    white-space: nowrap;
}

.footer-newsletter-form .wpcf7-form-control.wpcf7-submit:hover {
    background: var(--color-bg-dark);
}

/* Checkbox/acceptance — no white background */
.footer-newsletter-form .wpcf7-acceptance,
.footer-newsletter-form .wpcf7-acceptance .wpcf7-list-item {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.footer-newsletter-form .wpcf7-acceptance .wpcf7-list-item-label {
    color: var(--color-primary-fg);
    font-size: var(--text-sm);
    opacity: 0.8;
}

.footer-newsletter-form label {
    color: var(--color-primary-fg);
    font-weight: var(--font-medium);
    font-size: var(--text-sm);
}

/* Main footer grid */
.footer-main {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: var(--spacing-8) 0 var(--spacing-4);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    row-gap: var(--spacing-6);
    column-gap: var(--spacing-4);
    align-items: center;
}

/* Row 1: brand, nav, cta */
.footer-col--brand { grid-column: 1; grid-row: 1; }
.footer-col--nav   { grid-column: 2; grid-row: 1; }
.footer-col--cta   { grid-column: 3; grid-row: 1; justify-self: end; }

/* Row 2: info spans full width, social overlaps center */
.footer-col--info {
    grid-column: 1 / -1;
    grid-row: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-4);
    padding-top: var(--spacing-4);
}

.footer-col--social {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-self: center;
    padding-top: var(--spacing-4);
    z-index: 1;
}

/* Logo */
.footer-logo {
    height: 28px;
    width: auto;
    display: block;
    filter: brightness(0) invert(1);
}

.footer-logo-link {
    display: inline-flex;
}

/* Social icons */
.footer-social {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
}

.footer-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-on-dark-muted);
    background: none;
    border: none;
    transition: color var(--transition), opacity var(--transition);
    text-decoration: none;
    opacity: 0.85;
}

.footer-social-link .material-symbols-rounded {
    font-size: 18px;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 20;
}

.footer-social-link:hover {
    color: var(--color-text-on-dark);
    opacity: 1;
}

/* Footer nav — centered */
.footer-col--nav {
    display: flex;
    justify-content: center;
}

.footer-col--nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-1);
}

.footer-col--nav a {
    color: var(--color-text-on-dark-muted);
    font-size: var(--text-sm);
    text-decoration: none;
    padding: var(--spacing-1) var(--spacing-2);
    position: relative;
    transition: color var(--transition);
}

.footer-col--nav a::after {
    content: '';
    position: absolute;
    left: var(--spacing-2);
    right: var(--spacing-2);
    bottom: -1px;
    height: 1.5px;
    background: var(--color-primary);
    border-radius: var(--radius-full);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--transition);
}

.footer-col--nav a:hover {
    color: var(--color-text-on-dark);
}

.footer-col--nav a:hover::after {
    transform: scaleX(1);
}

/* Free Trial CTA */
.footer-col--cta {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.footer-cta-btn {
    display: inline-flex !important;
    align-items: center;
    gap: var(--spacing-1);
}

.footer-cta-icon {
    font-size: 16px;
    font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 20;
}

/* Copyright */
.footer-copyright {
    font-size: var(--text-xs);
    color: var(--color-text-on-dark-muted);
    margin: 0;
    line-height: var(--leading-relaxed);
}

.footer-copyright a {
    color: var(--color-text-on-dark-muted);
    text-decoration: none;
    transition: color var(--transition);
}

.footer-copyright a:hover {
    color: var(--color-text-on-dark);
}

/* Legal links */
.footer-legal-links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    gap: var(--spacing-4);
    flex-wrap: wrap;
}

.footer-legal-links a {
    color: var(--color-text-on-dark-muted);
    font-size: var(--text-xs);
    text-decoration: none;
    position: relative;
    display: inline-block;
    transition: color var(--transition);
}

.footer-legal-links a::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 1.5px;
    background: var(--color-primary);
    border-radius: var(--radius-full);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--transition);
}

.footer-legal-links a:hover {
    color: var(--color-text-on-dark);
}

.footer-legal-links a:hover::after {
    transform: scaleX(1);
}

/* ---------- Footer Mobile ---------- */
@media (max-width: 768px) {
    .footer-grid {
        grid-template-columns: 1fr;
        row-gap: var(--spacing-6);
    }

    .footer-col--brand {
        grid-column: 1;
        grid-row: 1;
    }

    .footer-col--nav {
        grid-column: 1;
        grid-row: 2;
        justify-content: flex-start;
        align-self: start;
    }

    .footer-col--nav ul {
        flex-direction: row;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: var(--spacing-1);
    }

    .footer-col--cta {
        grid-column: 1;
        grid-row: 3;
        justify-self: center;
        justify-content: center;
    }

    .footer-col--cta .footer-cta-btn {
        width: 80vw;
        max-width: 100%;
        display: flex !important;
        justify-content: center;
        font-size: var(--text-base);
    }

    .footer-col--social {
        grid-column: 1;
        grid-row: 4;
        justify-self: start;
        padding-top: 0;
    }

    .footer-col--social .footer-social-link svg {
        width: 22px;
        height: 22px;
    }

    .footer-col--social .footer-social-link .material-symbols-rounded {
        font-size: 22px;
    }

    .footer-col--info {
        grid-column: 1;
        grid-row: 5;
        display: flex;
        flex-direction: column-reverse;
        align-items: center;
        justify-content: center;
        text-align: center;
        padding-top: var(--spacing-4);
        gap: var(--spacing-2);
    }

    .footer-col--info .footer-copyright {
        margin: 0;
        align-self: center;
        line-height: var(--leading-normal);
        padding: 0;
        height: auto;
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        justify-content: center;
    }

    .footer-col--info .footer-legal-links {
        flex-direction: row;
        align-items: center;
        align-self: center;
        justify-content: center;
        gap: var(--spacing-3);
        flex-wrap: wrap;
        margin: 0;
        padding: 0;
        line-height: var(--leading-normal);
        height: auto;
    }

    .footer-col--info .footer-legal-links li,
    .footer-col--info .footer-legal-links a {
        line-height: 24px;
        margin: 0;
        padding: 0;
        display: inline-flex;
        align-items: center;
    }

    /* Newsletter: submit full width */
    .footer-newsletter-form .wpcf7-form > p:has(.wpcf7-submit) {
        flex: 0 0 100%;
    }

    .footer-newsletter-form .wpcf7-form-control.wpcf7-submit {
        width: 100%;
    }
}

/* ---------- Contact Page ---------- */
.contact-layout {
    max-width: 700px;
}

/* ---------- 404 ---------- */
.error-404-section {
    padding: var(--spacing-24) 0;
    text-align: center;
}

.error-404-content {
    max-width: 560px;
    margin: 0 auto;
}

.error-404-code {
    display: block;
    font-size: clamp(6rem, 15vw, 10rem);
    font-weight: var(--font-black);
    line-height: 1;
    letter-spacing: -0.04em;
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: var(--spacing-4);
}

.error-404-title {
    font-size: var(--text-3xl);
    font-weight: var(--font-bold);
    color: var(--color-text);
    margin: 0 0 var(--spacing-4);
}

.error-404-desc {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    line-height: var(--leading-relaxed);
    margin: 0 0 var(--spacing-8);
}

.error-404-search {
    max-width: 420px;
    margin: 0 auto var(--spacing-8);
}

.error-404-links {
    display: flex;
    justify-content: center;
    gap: var(--spacing-3);
    flex-wrap: wrap;
}

@media (max-width: 768px) {
    .error-404-section {
        padding: var(--spacing-16) 0;
    }

    .error-404-links {
        flex-direction: column;
        align-items: center;
    }
}

/* ---------- Search Form ---------- */
.search-form {
    display: flex;
    gap: var(--spacing-sm);
}

.search-form .search-field {
    flex: 1;
    padding: var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 1rem;
    font-family: var(--font-sans);
}

.search-form .search-field:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(115, 119, 231, 0.12);
}

.search-form .search-submit {
    background: var(--color-accent);
    color: var(--color-accent-fg);
    border: none;
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--radius);
    font-weight: var(--font-semibold);
    cursor: pointer;
    transition: background var(--transition), box-shadow var(--transition);
}

.search-form .search-submit:hover {
    background: var(--color-accent-hover);
    box-shadow: var(--shadow-accent);
}

/* ---------- WordPress Alignment ---------- */
.alignwide {
    max-width: var(--container-wide);
    margin-inline: auto;
}

.alignfull {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
}

.aligncenter {
    display: block;
    margin-inline: auto;
}

.alignleft {
    float: left;
    margin: 0 var(--spacing-lg) var(--spacing-lg) 0;
}

.alignright {
    float: right;
    margin: 0 0 var(--spacing-lg) var(--spacing-lg);
}

/* ---------- WordPress Gallery ---------- */
.wp-block-gallery {
    margin-bottom: var(--spacing-lg);
}

/* ---------- Page Links ---------- */
.page-links {
    clear: both;
    margin: var(--spacing-lg) 0;
    font-weight: 600;
}

/* ---------- Floating Demo Button ---------- */
.floating-demo-btn {
    position: fixed;
    bottom: var(--spacing-xl);
    right: var(--spacing-lg);
    background: var(--color-bg-darkest);
    color: var(--color-white);
    padding: 0.85em 1.5em;
    border-radius: var(--radius);
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    font-weight: var(--font-semibold);
    font-size: var(--text-base);
    box-shadow: var(--shadow-xl);
    z-index: 9999;
    
    /* Invisible by default */
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease, background 0.3s ease, color 0.3s ease;
    text-decoration: none;
    border: 1px solid rgba(255,255,255,0.1);
}

.floating-demo-btn .material-symbols-rounded {
    font-size: 24px;
    color: var(--color-primary);
}

.floating-demo-btn:hover {
    background: var(--color-bg-dark);
    color: var(--color-white);
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.25);
}

.floating-demo-btn.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

@media (max-width: 768px) {
    .floating-demo-btn {
        bottom: var(--spacing-lg);
        right: var(--spacing-md);
        padding: 0.75em 1.25em;
        font-size: var(--text-sm);
    }
}

/* ==========================================================================
   Contact Page (Standalone – no header/footer)
   ========================================================================== */

.contact-standalone {
    margin: 0;
    padding: 0;
    height: 100vh;
    width: 100vw;
    overflow: hidden;
}

.contact-page-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    height: 100vh;
    width: 100vw;
    overflow: hidden;
}

/* ---- Left: Info Panel ---- */
.contact-panel--info {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 8vh;
    padding-bottom: 8vh;
}

.contact-panel--info .contact-panel-inner {
    position: relative;
    z-index: 2;
    padding: var(--spacing-xl) var(--spacing-xl);
    max-width: 480px;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.contact-back-link {
    position: absolute;
    top: var(--spacing-xl);
    left: var(--spacing-xl);
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    color: var(--color-text-on-dark-muted);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    z-index: 10;
    transition: color var(--transition);
}

.contact-back-link .material-symbols-rounded {
    font-size: 18px;
}

.contact-back-link:hover {
    color: var(--color-white);
}

.contact-logo-text {
    font-family: var(--font-sans);
    font-size: clamp(2rem, 4vw, 2.5rem);
    font-weight: bold;
    color: var(--color-white);
    text-decoration: none;
    line-height: 1;
    letter-spacing: -0.02em;
    margin-bottom: var(--spacing-md);
}

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

.contact-info-title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: var(--font-bold);
    color: var(--color-white);
    line-height: var(--leading-tight);
    margin: 0;
}

.contact-info-desc {
    font-size: var(--text-base);
    color: var(--color-text-on-dark-muted);
    line-height: var(--leading-relaxed);
    margin: 0;
}

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

.contact-detail-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--text-base);
}

.contact-detail-item .material-symbols-rounded {
    font-size: 22px;
    color: var(--color-accent);
}

.contact-detail-item a {
    color: var(--color-text-on-dark);
    text-decoration: none;
    transition: color var(--transition);
}

.contact-detail-item a:hover {
    color: var(--color-primary);
}

/* Social */
.contact-social {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: auto;
}

.contact-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-on-dark-muted);
    transition: background var(--transition), color var(--transition);
}

.contact-social-link:hover {
    background: rgba(255, 255, 255, 0.12);
    color: var(--color-white);
}

/* Decorative glow */
.contact-panel-glow {
    position: absolute;
    bottom: -15%;
    right: -15%;
    width: 350px;
    height: 350px;
    background: var(--color-accent);
    filter: blur(120px);
    opacity: 0.12;
    border-radius: 50%;
    pointer-events: none;
    z-index: 1;
}

/* ---- Right: Form Panel ---- */
.contact-panel--form {
    background: var(--color-bg);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 8vh;
    padding-bottom: 8vh;
}

.contact-panel--form .contact-panel-inner {
    padding: var(--spacing-xl) var(--spacing-xl);
    max-width: 520px;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}


/* ---- CF7 Form Styling ---- */
.contact-form-wrap .wpcf7-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.contact-form-wrap .wpcf7-form p {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.contact-form-wrap .wpcf7-form label {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-secondary);
}

.contact-form-wrap .wpcf7-form input[type="text"],
.contact-form-wrap .wpcf7-form input[type="email"],
.contact-form-wrap .wpcf7-form input[type="tel"],
.contact-form-wrap .wpcf7-form input[type="url"],
.contact-form-wrap .wpcf7-form textarea,
.contact-form-wrap .wpcf7-form select {
    width: 100%;
    padding: 0.65em 0.85em;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    color: var(--color-text);
    background: var(--color-white);
    transition: border-color var(--transition), box-shadow var(--transition);
}

.contact-form-wrap .wpcf7-form input:focus,
.contact-form-wrap .wpcf7-form textarea:focus,
.contact-form-wrap .wpcf7-form select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(115, 119, 231, 0.12);
}

.contact-form-wrap .wpcf7-form textarea {
    resize: vertical;
    min-height: 100px;
    height: 100px;
}

.contact-form-wrap .wpcf7-form input[type="submit"] {
    background: var(--color-primary);
    color: var(--color-primary-fg);
    border: 2px solid var(--color-primary);
    padding: 0.85em 2em;
    border-radius: var(--radius);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    cursor: pointer;
    transition: background var(--transition), box-shadow var(--transition);
    width: 100%;
}

.contact-form-wrap .wpcf7-form input[type="submit"]:hover {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    box-shadow: var(--shadow-primary);
}

.contact-form-wrap .wpcf7-not-valid-tip {
    color: #ef4444;
    font-size: var(--text-sm);
    margin-top: var(--spacing-xs);
}

.contact-form-wrap .wpcf7-response-output {
    border-radius: var(--radius);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--text-sm);
    margin: var(--spacing-md) 0 0;
}

/* Custom Checkbox & Acceptance Styling */
.contact-form-wrap .wpcf7-form .wpcf7-list-item-label,
.contact-form-wrap .wpcf7-form .wpcf7-acceptance label span {
    font-size: 75%;
}

.contact-form-wrap .wpcf7-form .wpcf7-form-control.wpcf7-acceptance,
.contact-form-wrap .wpcf7-form input[type="checkbox"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    margin: 0;
    padding: 0;
}

/* ---- Mobile ---- */
@media (max-width: 900px) {
    .contact-standalone,
    .contact-page-wrap {
        height: auto;
        overflow: visible;
    }

    .contact-page-wrap {
        grid-template-columns: 1fr;
    }

    .contact-panel--info .contact-panel-inner {
        padding: calc(var(--spacing-xl) * 2) var(--spacing-lg) var(--spacing-xl);
    }

    .contact-back-link {
        top: var(--spacing-md);
        left: var(--spacing-lg);
    }

    .contact-panel--form .contact-panel-inner {
        padding: var(--spacing-xl) var(--spacing-lg);
    }

    .contact-info-title {
        font-size: clamp(1.75rem, 5vw, 2.5rem);
    }
}

/* ==========================================================================
   Pricing Page
   ========================================================================== */

/* ---------- Pricing Intro ---------- */
.pricing-page {
    background: var(--color-bg-1);
}

.pricing-intro {
    text-align: left;
    padding: var(--spacing-24) 0 var(--spacing-12);
}

.pricing-intro-banner {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl) var(--spacing-2xl);
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-xl);
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: var(--spacing-xl);
}

.pricing-intro-banner::before {
    content: '';
    position: absolute;
    top: -30%;
    left: -5%;
    width: 500px;
    height: 500px;
    background: var(--color-accent);
    filter: blur(180px);
    opacity: 0.2;
    pointer-events: none;
    border-radius: 50%;
}

.pricing-intro-banner::after {
    content: '';
    position: absolute;
    bottom: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: var(--color-primary);
    filter: blur(120px);
    opacity: 0.1;
    pointer-events: none;
    border-radius: 50%;
}

.pricing-intro-inner {
    position: relative;
    z-index: 2;
    max-width: 640px;
    flex: 1;
}

.pricing-intro-title {
    font-size: clamp(2rem, 5vw, var(--text-4xl));
    font-weight: var(--font-bold);
    letter-spacing: -0.02em;
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-6);
    color: var(--color-white);
}

.pricing-intro-lead {
    font-size: var(--text-md);
    line-height: var(--leading-normal);
    color: var(--color-text-on-dark-muted);
    max-width: 640px;
    margin: 0;
}

/* ---------- Pricing Tabs (Plans / Custom API) ---------- */
.pricing-tabs {
    display: inline-flex;
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-full);
    padding: 4px;
    gap: 4px;
    position: relative;
    z-index: 2;
    flex-shrink: 0;
    align-self: flex-end;
}

.pricing-tab {
    padding: 0.5rem 1.5rem;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    border-radius: var(--radius-full);
    border: none;
    background: transparent;
    color: var(--color-text-on-dark-muted);
    cursor: pointer;
    transition: background var(--transition), color var(--transition), box-shadow var(--transition);
    font-family: var(--font-sans);
}

.pricing-tab.is-active {
    background: var(--color-white);
    color: var(--color-text);
    box-shadow: var(--shadow-sm);
}

.pricing-tab:hover:not(.is-active) {
    color: var(--color-white);
}

/* ---------- Pricing Panels ---------- */
.pricing-panel {
    display: none;
    padding-bottom: var(--spacing-24);
}

.pricing-panel.is-active {
    display: block;
}

/* ---------- Section Headers ---------- */
.pricing-section-header {
    text-align: left;
    margin-bottom: var(--spacing-12);
}

.pricing-section-title {
    font-size: clamp(1.5rem, 4vw, var(--text-3xl));
    font-weight: var(--font-bold);
    letter-spacing: -0.02em;
    margin: 0 0 var(--spacing-4);
    color: var(--color-text);
}

.pricing-section-subtitle {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
    max-width: 640px;
    margin: 0 0 var(--spacing-8);
}

/* ---------- Billing Toggle ---------- */
.billing-toggle {
    display: inline-flex;
    background: var(--color-bg-muted);
    border-radius: var(--radius-full);
    padding: 4px;
    gap: 4px;
    margin: 0;
}

.billing-toggle-btn {
    padding: 0.5rem 1.25rem;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    border-radius: var(--radius-full);
    border: none;
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: background var(--transition), color var(--transition), box-shadow var(--transition);
    font-family: var(--font-sans);
}

.billing-toggle-btn.is-active {
    background: var(--color-white);
    color: var(--color-text);
    box-shadow: var(--shadow-sm);
}

.billing-toggle-btn:hover:not(.is-active) {
    color: var(--color-text);
}

/* panel layout */
.pricing-panel--plans > .container {
    display: block;
}

/* ---------- Pricing Grid (3 cards) ---------- */
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-8);
    max-width: 1100px;
    margin: 0 auto var(--spacing-24);
}

/* ---------- Plan Card ---------- */
.plan-card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    position: relative;
    background: var(--color-bg-muted);
    transition: box-shadow var(--transition), border-color var(--transition);
}

.plan-card:hover {
    box-shadow: var(--shadow-md);
}

.plan-card--popular {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-accent);
}

.plan-card-badge {
    position: absolute;
    top: calc(-1 * 0.75rem);
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-accent);
    color: var(--color-accent-fg);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.25rem 0.75rem;
    border-radius: var(--radius-full);
    white-space: nowrap;
}

.plan-card-head {
    margin-bottom: var(--spacing-4);
}

.plan-card-name {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    margin: 0 0 var(--spacing-1);
    color: var(--color-text);
}

.plan-card-audience {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.plan-card-price {
    margin-bottom: var(--spacing-1);
}

.plan-price {
    font-size: var(--text-3xl);
    font-weight: var(--font-black);
    letter-spacing: -0.02em;
    color: var(--color-text);
}

.plan-period {
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--color-text-muted);
}

.plan-billing-label {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    display: block;
    margin-bottom: var(--spacing-6);
}

/* ---------- Plan Features List ---------- */
.plan-features {
    list-style: none;
    padding: 0;
    margin: 0 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
    padding-bottom: var(--spacing-8);
}

.plan-features li {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: var(--text-sm);
    color: var(--color-text);
    line-height: var(--leading-snug);
}

.plan-feature-icon {
    font-size: 18px;
    color: var(--color-accent);
    flex-shrink: 0;
}

.plan-feature-icon--highlight {
    color: var(--color-accent);
}

.plan-cta {
    width: 100%;
    margin-top: auto;
}

/* ---------- Plan CTA Dropdown ---------- */
.plan-cta-wrap {
    position: relative;
    margin-top: auto;
    width: 100%;
}

.plan-cta-toggle {
    width: 100%;
}

.plan-cta-dropdown {
    display: none;
    position: absolute;
    bottom: calc(100% + var(--spacing-2));
    left: 0;
    right: 0;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    z-index: 50;
    flex-direction: column;
}

.plan-cta-dropdown.is-open {
    display: flex;
}

.plan-cta-option {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-4);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-text);
    text-decoration: none;
    transition: background var(--transition), color var(--transition);
}

.plan-cta-option:hover {
    background: var(--color-bg-muted);
    color: var(--color-accent);
}

.plan-cta-option .material-symbols-rounded {
    font-size: 18px;
    color: var(--color-accent);
}

/* ---------- Compare Plans ---------- */
.compare-plans {
    max-width: 1100px;
    margin: 0 auto;
}

.compare-plans-title {
    font-size: clamp(1.5rem, 4vw, var(--text-2xl));
    font-weight: var(--font-bold);
    letter-spacing: -0.02em;
    margin: 0 0 var(--spacing-4);
    text-align: center;
    color: var(--color-text);
}

.compare-plans-intro {
    text-align: center;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin: 0 auto var(--spacing-12);
    max-width: 640px;
    display: none;
}

.compare-plans-intro.is-active {
    display: block;
}

/* ---------- Feature Groups ---------- */
.feature-group {
    margin-bottom: var(--spacing-12);
}

.feature-group-title {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    color: var(--color-text);
    margin: 0 0 var(--spacing-6);
    padding-bottom: var(--spacing-3);
    border-bottom: 1px solid var(--color-border);
}

/* ---------- Feature Row ---------- */
.feature-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-8);
    padding: var(--spacing-6) 0;
    border-bottom: 1px solid var(--color-border);
}

.feature-row:last-child {
    border-bottom: none;
}

.feature-row-name {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-text);
    margin: 0 0 var(--spacing-2);
}

.feature-row-desc {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
    margin: 0;
}

.feature-row-values {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-4);
    align-content: start;
}

.feature-value {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.feature-plan-label {
    font-size: var(--text-xs);
    font-weight: var(--font-medium);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* ---------- Feature Checklist ---------- */
.feature-checklist {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-3) var(--spacing-8);
}

.feature-checklist li {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    font-size: var(--text-sm);
    color: var(--color-text);
}

.feature-check-icon {
    font-size: 18px;
    color: var(--color-accent);
    flex-shrink: 0;
}

.feature-soon {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    font-style: italic;
    margin-left: var(--spacing-1);
}

/* Descriptive checklists (with sub-text) */
.feature-checklist--descriptive li {
    align-items: flex-start;
}

.feature-checklist--descriptive li div {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.feature-checklist--descriptive li div strong {
    font-weight: var(--font-semibold);
}

.feature-checklist--descriptive li div span {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
}

/* ---------- Custom API Overview ---------- */
.custom-api-overview {
    text-align: left;
    max-width: 900px;
    margin: 0 auto var(--spacing-16);
    background: var(--color-bg-muted);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    border: 1px solid var(--color-border);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-lg);
}

.custom-api-overview::before {
    content: '';
    position: absolute;
    bottom: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: var(--color-primary);
    filter: blur(100px);
    opacity: 0.1;
    pointer-events: none;
    border-radius: 50%;
}

.custom-api-overview > * {
    position: relative;
    z-index: 2;
}

.custom-api-overview-left {
    flex: 1;
}

.custom-api-overview-right {
    flex-shrink: 0;
    max-width: 320px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.custom-api-overview .pricing-section-title {
    color: var(--color-text-main);
}

.custom-api-lead {
    font-size: var(--text-md);
    color: var(--color-text-main);
    line-height: var(--leading-normal);
    margin: 0 0 var(--spacing-4);
}

.custom-api-text {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
    margin: 0;
}

.custom-api-note {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-accent);
    margin: 0 0 var(--spacing-6);
}

.custom-api-cta {
    margin: 0;
}

/* ---------- Custom API Pricing (Calculator) ---------- */
.custom-api-pricing {
    max-width: 1100px;
    margin: 0 auto var(--spacing-16);
}

.custom-api-pricing-title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--color-text);
    margin: 0 0 var(--spacing-8);
}

.custom-api-calc {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-8);
    align-items: start;
}

.calc-row {
    padding: var(--spacing-4) 0;
    border-bottom: 1px solid var(--color-border);
}

.calc-row:first-child {
    border-top: 1px solid var(--color-border);
}

.calc-row-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: var(--spacing-3);
}

.calc-row-name {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-text);
}

.calc-row-note {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.calc-row-control {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.calc-btn {
    width: 32px;
    height: 32px;
    border-radius: var(--radius);
    border: 1px solid var(--color-border);
    background: var(--color-white);
    color: var(--color-text);
    font-size: var(--text-md);
    font-weight: var(--font-bold);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition), border-color var(--transition);
    font-family: var(--font-sans);
    line-height: 1;
}

.calc-btn:hover {
    background: var(--color-bg-muted);
    border-color: var(--color-accent);
}

.calc-input {
    width: 120px;
    text-align: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-2) var(--spacing-3);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    font-family: var(--font-sans);
    color: var(--color-text);
    background: var(--color-white);
    -moz-appearance: textfield;\n    appearance: textfield;
}

.calc-input::-webkit-outer-spin-button,
.calc-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.calc-row-subtotal {
    display: block;
    margin-top: var(--spacing-2);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-accent);
}

.custom-api-disclaimer {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin: var(--spacing-4) 0 var(--spacing-12);
    font-style: italic;
}

/* ---------- Custom API Summary Card ---------- */
.custom-api-summary {
    background: var(--color-bg-dark);
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    text-align: center;
    color: var(--color-text-on-dark);
}

.custom-api-summary-title {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    margin: 0 0 var(--spacing-4);
    color: var(--color-text-on-dark);
}

.custom-api-summary-total {
    font-size: var(--text-2xl);
    font-weight: var(--font-black);
    margin-bottom: var(--spacing-6);
    color: var(--color-primary);
}

.custom-api-summary-lines {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-8);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.custom-api-summary-lines li {
    font-size: var(--text-sm);
    color: var(--color-text-on-dark-muted);
}

.custom-api-summary-lines li strong {
    color: var(--color-text-on-dark);
}

.custom-api-summary-btn {
    width: 100%;
    max-width: 280px;
    margin-bottom: var(--spacing-4);
}

.custom-api-billing-note {
    font-size: var(--text-xs);
    color: var(--color-text-on-dark-muted);
    margin: 0;
}

/* ---------- Custom API Features ---------- */
.custom-api-features {
    max-width: 1100px;
    margin: 0 auto;
}

.custom-api-features .pricing-section-title {
    text-align: left;
}

.custom-api-features .pricing-section-subtitle {
    text-align: left;
    margin-bottom: var(--spacing-12);
}

/* Custom API includes note */
.custom-api-includes-note {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-3);
    padding: var(--spacing-4) var(--spacing-6);
    background: var(--color-bg-muted);
    border-radius: var(--radius);
    border-left: 3px solid var(--color-accent);
    margin-bottom: var(--spacing-12);
}

.custom-api-includes-note .material-symbols-rounded {
    font-size: 20px;
    color: var(--color-accent);
    flex-shrink: 0;
    margin-top: 2px;
}

.custom-api-includes-note p {
    font-size: var(--text-sm);
    color: var(--color-text);
    line-height: var(--leading-normal);
    margin: 0;
}

/* ---------- Pricing Page Responsive ---------- */
@media (max-width: 1024px) {
    .pricing-grid {
        grid-template-columns: repeat(2, 1fr);
        max-width: 720px;
    }

    .pricing-grid .plan-card:last-child {
        grid-column: 1 / -1;
        max-width: 360px;
        justify-self: center;
    }

    .feature-checklist {
        grid-template-columns: repeat(2, 1fr);
    }

    .pricing-intro-banner {
        padding: var(--spacing-xl) var(--spacing-lg);
        flex-direction: column;
        align-items: flex-start;
    }

    .custom-api-overview {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-4);
    }

    .custom-api-overview-left {
        max-width: 100%;
    }
}

@media (max-width: 768px) {
    .pricing-intro {
        padding: var(--spacing-6) 0 var(--spacing-8);
    }

    .pricing-grid {
        grid-template-columns: 1fr;
        max-width: 440px;
    }

    .pricing-grid .plan-card:last-child {
        max-width: 100%;
        justify-self: stretch;
    }

    .feature-row {
        grid-template-columns: 1fr;
        gap: var(--spacing-4);
    }

    .feature-row-values {
        grid-template-columns: repeat(2, 1fr);
    }

    .feature-checklist {
        grid-template-columns: 1fr;
    }

    .custom-api-calc {
        grid-template-columns: 1fr;
    }

    .custom-api-row {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-2);
    }

    .custom-api-row-price {
        text-align: left;
    }

    .custom-api-overview {
        padding: var(--spacing-lg);
    }
}

/* ==========================================================================
   Demo Page
   ========================================================================== */

.demo-page {
    background: var(--color-bg-1);
}

/* ---------- Demo Intro ---------- */
.demo-intro {
    text-align: left;
    padding: var(--spacing-24) 0 var(--spacing-6);
}

.demo-intro-banner {
    background: var(--color-bg-darkest);
    color: var(--color-text-on-dark);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl) var(--spacing-12);
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-8);
}

.demo-intro-banner::before {
    content: '';
    position: absolute;
    top: -150px;
    right: -100px;
    width: 500px;
    height: 500px;
    background: var(--color-accent);
    filter: blur(140px);
    opacity: 0.15;
    pointer-events: none;
    border-radius: 50%;
}

.demo-intro-content {
    position: relative;
    z-index: 2;
    flex: 1;
    max-width: 540px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.demo-status-bar {
    background: var(--color-bg-dark);
    border-radius: var(--radius-full);
    padding: var(--spacing-2) var(--spacing-4);
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    border: 1px solid var(--color-border-on-dark);
    margin-bottom: var(--spacing-3);
}

.demo-status-bar .status-text {
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    color: var(--color-white);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.demo-intro-title {
    font-size: var(--text-3xl);
    font-weight: var(--font-bold);
    margin: 0 0 var(--spacing-2);
    color: var(--color-white);
    text-align: left;
}

.demo-intro-lead {
    font-size: var(--text-lg);
    color: var(--color-text-on-dark-muted);
    line-height: var(--leading-relaxed);
    margin: 0;
    text-align: left;
}

.demo-actions {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: var(--spacing-4);
    flex-shrink: 0;
    min-width: 320px;
}

.demo-hero-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2);
    height: 48px; /* Match height of password box */
    width: 100%;
}

/* ---------- Password Copy Box ---------- */
.demo-password-box {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-3);
    background: rgba(255, 255, 255, 0.05); /* semi-transparent for dark mode */
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0 var(--spacing-2) 0 var(--spacing-4);
    height: 48px;
    border-radius: var(--radius-full);
    position: relative;
    cursor: pointer;
    transition: all var(--transition);
    width: 100%;
    justify-content: space-between;
}

.demo-password-box:hover {
    border-color: var(--color-primary);
    background: rgba(255, 255, 255, 0.08);
}

.demo-password-box.is-copied {
    border-color: #10B981; /* green */
    background: rgba(16, 185, 129, 0.1);
}

.password-label {
    font-size: var(--text-sm);
    color: var(--color-text-on-dark-muted);
}

.password-value {
    font-family: var(--font-mono, monospace);
    font-weight: var(--font-bold);
    color: var(--color-white);
    letter-spacing: 0.05em;
}

.password-copy-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-text-on-dark);
    border-radius: 50%;
    cursor: pointer;
    transition: all var(--transition);
}

.demo-password-box:hover .password-copy-btn {
    background: rgba(255, 255, 255, 0.2);
    color: var(--color-white);
}

.demo-password-box.is-copied .password-copy-btn {
    background: #10B981;
    color: var(--color-white);
}

.demo-password-box .copy-feedback {
    position: absolute;
    top: -36px;
    right: 0;
    background: #10B981;
    color: var(--color-white);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    padding: var(--spacing-1) var(--spacing-2);
    border-radius: var(--radius-sm);
    opacity: 0;
    transform: translateY(8px);
    transition: all var(--transition);
    pointer-events: none;
}

.demo-password-box.is-copied .copy-feedback {
    opacity: 1;
    transform: translateY(0);
}

.demo-password-box .copy-feedback::after {
    content: '';
    position: absolute;
    bottom: -4px;
    right: 12px;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid #10B981;
}

/* ---------- Demo Steps ---------- */
.demo-steps-sec {
    padding: 0 0 var(--spacing-24);
}

.demo-steps-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-6);
    max-width: 1100px;
    margin: 0 auto;
}

.demo-step-card {
    background: var(--color-bg-dark);
    border: 1px solid var(--color-border-on-dark);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    text-align: left;
    transition: box-shadow var(--transition), border-color var(--transition);
    position: relative;
    overflow: hidden;
    min-height: 180px;
}

.demo-step-bg-icon {
    position: absolute;
    bottom: -15px;
    right: -15px;
    font-size: 110px;
    opacity: 0.05;
    color: var(--color-white);
    z-index: 1;
    pointer-events: none;
}

.demo-step-card::before {
    content: '';
    position: absolute;
    bottom: -80px;
    right: -80px;
    width: 200px;
    height: 200px;
    filter: blur(80px);
    opacity: 0;
    pointer-events: none;
    border-radius: 50%;
    z-index: 0;
    transition: opacity var(--transition);
}

/* Card 1: dark bg with accent (purple) gradient */
.demo-step-1::before {
    background: var(--color-accent);
    opacity: 0.15;
}

/* Card 2: dark bg with primary (blue) gradient */
.demo-step-2::before {
    background: var(--color-primary);
    opacity: 0.15;
}

/* Card 3: primary (blue) bg, dark text, no gradient */
.demo-step-3 {
    background: var(--color-primary);
    border-color: var(--color-primary);
}
.demo-step-3 .demo-step-title {
    color: #111113;
}
.demo-step-3 .demo-step-desc {
    color: rgba(17, 17, 19, 0.8);
}
.demo-step-3 .demo-step-bg-icon {
    color: #111113;
    opacity: 0.1;
}
.demo-step-3 strong {
    color: #111113;
}

/* Card 4: darkest bg with accent (purple) gradient */
.demo-step-4 {
    background: var(--color-bg-darkest);
}
.demo-step-4::before {
    background: var(--color-accent);
    opacity: 0.15;
}

.demo-step-title,
.demo-step-desc,
.demo-step-icon {
    position: relative;
    z-index: 2;
}

.demo-step-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
}

.demo-step-card.demo-step-3:hover {
    border-color: #111113;
    box-shadow: none;
}

.demo-step-title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--color-white);
    margin: 0 0 var(--spacing-2);
    line-height: var(--leading-snug);
}

.demo-step-desc {
    font-size: var(--text-base);
    color: var(--color-text-on-dark-muted);
    line-height: var(--leading-relaxed);
    margin: 0;
    max-width: 85%;
}

/* ---------- Demo CTA Card ---------- */
.demo-cta-card {
    background: var(--color-bg-muted);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl) var(--spacing-2xl);
    max-width: 1100px;
    margin: var(--spacing-8) auto 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-8);
    transition: box-shadow var(--transition), border-color var(--transition);
}

.demo-cta-card:hover {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-md);
}

.demo-cta-content {
    flex: 1;
}

.demo-cta-title {
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--color-text-main);
    margin: 0 0 var(--spacing-2);
    line-height: var(--leading-snug);
}

.demo-cta-desc {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    margin: 0;
    line-height: var(--leading-relaxed);
}

.demo-cta-action {
    flex-shrink: 0;
}

.demo-cta-btn {
    min-width: 200px;
    justify-content: center;
}

/* ---------- Demo Responsive ---------- */
@media (max-width: 1024px) {
    .demo-intro-banner {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-8);
        padding: var(--spacing-xl) var(--spacing-4);
    }
    
    .demo-intro-content {
        max-width: 100%;
        padding-top: 0;
    }
    
    .demo-actions {
        width: 100%;
        min-width: unset;
    }
}

@media (max-width: 768px) {
    .demo-intro {
        padding: var(--spacing-6) 0 var(--spacing-6);
    }

    .demo-intro-title {
        font-size: var(--text-3xl);
    }

    .demo-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .demo-password-box {
        justify-content: space-between;
    }

    .demo-steps-grid {
        grid-template-columns: 1fr;
    }

    .demo-cta-card {
        flex-direction: column;
        align-items: flex-start;
        padding: var(--spacing-xl);
    }
    
    .demo-cta-btn {
        width: 100%;
    }
}

/* ==========================================================================
   Nav External Link Icon
   ========================================================================== */

.menu-item-external > a {
    display: inline-flex !important;
    align-items: center;
    gap: 4px;
}

.menu-item-external > a::before {
    content: none;
}

.nav-external-icon {
    font-size: 16px;
    line-height: 1;
    opacity: .6;
    order: 1;
}

/* ==========================================================================
   Page Template (Privacy Policy, Terms, etc.)
   ========================================================================== */

.site-main--page {
    background: var(--color-bg-1);
    padding-bottom: var(--spacing-24);
}

.page-container {
    max-width: 960px;
    margin: 0 auto;
    padding: var(--spacing-16) var(--spacing-md) var(--spacing-24);
}

.page-header {
    margin-bottom: var(--spacing-12);
    padding-bottom: var(--spacing-8);
    border-bottom: 1px solid var(--color-border);
}

.page-title {
    font-family: var(--font-sans);
    font-size: clamp(2rem, 5vw, 2.75rem);
    font-weight: var(--font-bold);
    color: var(--color-text);
    line-height: var(--leading-tight);
    letter-spacing: -0.02em;
    margin: 0 0 var(--spacing-3);
}

.page-updated {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin: 0;
}

/* --- Page body — shares article-body typography --- */
.page-body {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text);
}

.page-body p {
    margin: 0 0 var(--spacing-6);
}

.page-body h2 {
    font-family: var(--font-sans);
    font-size: clamp(1.35rem, 2.5vw, var(--text-2xl));
    font-weight: var(--font-bold);
    color: var(--color-text);
    line-height: var(--leading-tight);
    letter-spacing: -0.015em;
    margin: var(--spacing-14) 0 var(--spacing-4);
}

.page-body h3 {
    font-family: var(--font-sans);
    font-size: clamp(1.1rem, 2vw, var(--text-xl));
    font-weight: var(--font-semibold);
    color: var(--color-text);
    line-height: var(--leading-snug);
    margin: var(--spacing-10) 0 var(--spacing-3);
}

.page-body h4 {
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: var(--font-semibold);
    color: var(--color-text);
    line-height: var(--leading-snug);
    margin: var(--spacing-8) 0 var(--spacing-3);
}

.page-body a {
    color: var(--color-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: color var(--transition);
}

.page-body a:hover {
    color: var(--color-accent-hover);
}

.page-body ul,
.page-body ol {
    margin: 0 0 var(--spacing-6);
    padding-left: var(--spacing-8);
}

.page-body li {
    margin-bottom: var(--spacing-2);
    line-height: var(--leading-relaxed);
}

.page-body li::marker {
    color: var(--color-text-muted);
}

.page-body blockquote {
    margin: var(--spacing-10) 0;
    padding: var(--spacing-6) var(--spacing-8);
    border-left: 3px solid var(--color-accent);
    font-size: var(--text-lg);
    font-style: italic;
    color: var(--color-text-muted);
    line-height: var(--leading-normal);
}

.page-body blockquote p {
    margin: 0;
}

.page-body hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--spacing-12) auto;
    max-width: 100px;
}

.page-body strong {
    font-weight: var(--font-semibold);
    color: var(--color-text);
}

.page-body table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--spacing-8) 0;
    font-size: var(--text-base);
}

.page-body th,
.page-body td {
    padding: var(--spacing-3) var(--spacing-4);
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}

.page-body th {
    font-weight: var(--font-semibold);
    color: var(--color-text);
}

.page-body code {
    font-family: var(--font-mono);
    font-size: 0.875em;
    background: var(--color-bg-muted);
    padding: 0.15em 0.45em;
    border-radius: var(--radius-sm);
    color: var(--color-text);
}

.page-entry-footer {
    margin-top: var(--spacing-12);
    padding-top: var(--spacing-6);
    border-top: 1px solid var(--color-border);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

@media (max-width: 767px) {
    .page-container {
        padding-top: var(--spacing-12);
        padding-bottom: var(--spacing-16);
    }

    .page-title {
        font-size: clamp(1.75rem, 6vw, 2rem);
    }
}

/* ==========================================================================
   Cookie Banner
   ========================================================================== */

.cookie-banner {
    position: fixed;
    bottom: var(--spacing-lg);
    left: var(--spacing-lg);
    z-index: 9999;
    max-width: 340px;
    background: #2f3034;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    animation: cookieSlideIn .4s ease-out;
}

.cookie-banner[hidden] {
    display: none;
}

.cookie-banner-inner {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    padding: var(--spacing-lg) var(--spacing-xl);
}

.cookie-banner-icon {
    font-size: 28px;
    color: var(--color-primary);
}

.cookie-banner-text {
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--color-primary);
    margin: 0;
}

.cookie-banner-actions {
    display: flex;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-xs);
}

.cookie-btn {
    flex: 1;
    padding: var(--spacing-xs) var(--spacing-md);
    border: 2px solid transparent;
    border-radius: var(--radius);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    font-family: inherit;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.cookie-btn--accept {
    background: var(--color-primary);
    color: var(--color-primary-fg);
    border-color: var(--color-primary);
    box-shadow: var(--shadow-primary);
}

.cookie-btn--accept:hover {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    box-shadow: none;
}

.cookie-btn--reject {
    background: rgba(255, 255, 255, .08);
    color: var(--color-text-secondary);
    border-color: rgba(255, 255, 255, .15);
}

.cookie-btn--reject:hover {
    background: rgba(255, 255, 255, .14);
    color: var(--color-text-primary);
    border-color: rgba(255, 255, 255, .25);
}

@keyframes cookieSlideIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Mobile: pinned to bottom, full-width strip */
@media (max-width: 767px) {
    .cookie-banner {
        bottom: 0;
        left: 0;
        right: 0;
        max-width: none;
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    }

    .cookie-banner-inner {
        flex-direction: row;
        align-items: center;
        flex-wrap: wrap;
        padding: var(--spacing-md) var(--spacing-lg);
        gap: var(--spacing-xs);
    }

    .cookie-banner-icon {
        font-size: 22px;
    }

    .cookie-banner-text {
        flex: 1;
        min-width: 0;
    }

    .cookie-banner-actions {
        margin-top: 0;
        flex: 0 0 auto;
    }

    .cookie-btn {
        padding: var(--spacing-xs) var(--spacing-sm);
    }
}
