/* ─────────────────────────────────────────────────────────────────
 * Artificial Perfection — Design System v3 ("Atelier · Warm")
 *
 * Inspired by Anthropic / research-institute aesthetic. Warm cream
 * base, editorial serif, terracotta accent, abstract geometric
 * illustration over particle canvas.
 * ─────────────────────────────────────────────────────────────────── */

:root {
    /* ── Neutrals — paper base (original palette) ─────── */
    --ap-paper:         #FAF7F2;   /* warm cream (original) */
    --ap-paper-raised:  #FFFFFF;
    --ap-paper-sunk:    #F3EFE8;
    --ap-border:        #E8E2D7;
    --ap-border-strong: #D8CFBE;
    --ap-divider:       #EDE7DB;

    /* ── Ink ─────────────────────────────────────────── */
    --ap-ink:           #1A1A1A;
    --ap-ink-2:         #2E2E2C;
    --ap-ink-3:         #585651;
    --ap-ink-4:         #8A857C;
    --ap-ink-5:         #B5AFA3;

    /* ── PRIMARY ACCENT — Forest green (original brand) ── */
    --ap-accent:        #4D805E;
    --ap-accent-dark:   #3D664B;
    --ap-accent-darker: #2D4F38;
    --ap-accent-tint:   #EAF1EC;
    --ap-accent-tint-2: #D3E1D7;
    --ap-accent-glow:   rgba(77, 128, 94, 0.20);

    /* ── Tertiary / data ─────────────────────────────── */
    --ap-ochre:         #B8733C;
    --ap-ochre-tint:    #F6EADD;
    --ap-sand:          #C4A47E;
    --ap-sand-tint:     #EFE5D4;
    --ap-slate:         #475569;
    --ap-slate-tint:    #E2E8F0;

    /* Semantic */
    --ap-success:       #4D805E;
    --ap-success-tint:  #EAF1EC;
    --ap-warning:        #B8733C;
    --ap-warning-tint:   #F6EADD;
    --ap-warning-border: #F4D5B6;
    --ap-danger:         #9B2C2C;
    --ap-danger-tint:    #FDF0F0;
    --ap-danger-border:  #F4C9C9;
    --ap-info:           #3B5BA5;
    --ap-info-tint:      #E9EFF9;
    --ap-info-border:    #C8D4ED;

    /* Aliases so legacy code using --ap-brand still works */
    --ap-brand:         var(--ap-accent);
    --ap-brand-dark:    var(--ap-accent-dark);
    --ap-brand-darker:  var(--ap-accent-darker);
    --ap-brand-tint:    var(--ap-accent-tint);
    --ap-brand-tint-2:  var(--ap-accent-tint-2);
    --ap-forest:        var(--ap-accent);
    --ap-forest-tint:   var(--ap-accent-tint);

    /* ── Typography — Geometric sans (matching "artificial." logo) ──
     * Outfit has the single-story 'a' and rounded geometric forms that
     * match the logo. Space Grotesk had a double-story 'a' — wrong. */
    --ap-font-sans:    "Inter", "SF Pro Display", system-ui, -apple-system, "Segoe UI", sans-serif;
    --ap-font-display: "Outfit", "Onest", "Inter", system-ui, sans-serif;
    --ap-font-mono:    "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;

    /* Type scale */
    --ap-text-xs:      0.75rem;
    --ap-text-sm:      0.8125rem;
    --ap-text-base:    0.9375rem;
    --ap-text-md:      1rem;
    --ap-text-lg:      1.125rem;
    --ap-text-xl:      1.375rem;
    --ap-h6:           1.25rem;
    --ap-h5:           1.5rem;
    --ap-h4:           clamp(1.75rem, 2.5vw, 2.125rem);
    --ap-h3:           clamp(2rem, 3.2vw, 2.75rem);
    --ap-h2:           clamp(2.5rem, 4.5vw, 4rem);
    --ap-h1:           clamp(3rem, 7vw, 6.5rem);
    --ap-display:      clamp(4rem, 10vw, 9rem);

    /* Leading / tracking — geometric sans (tighter) */
    --ap-leading-tight:    1.0;
    --ap-leading-display:  0.92;
    --ap-leading-heading:  1.08;
    --ap-leading-body:     1.6;
    --ap-leading-prose:    1.72;
    --ap-track-display:  -0.045em;   /* tight for bold geometric sans */
    --ap-track-heading:  -0.03em;
    --ap-track-tight:    -0.015em;
    --ap-track-eyebrow:  0.08em;

    /* Spacing scale */
    --ap-space-1:  4px;
    --ap-space-2:  8px;
    --ap-space-3:  12px;
    --ap-space-4:  16px;
    --ap-space-5:  20px;
    --ap-space-6:  24px;
    --ap-space-8:  32px;
    --ap-space-10: 40px;
    --ap-space-12: 48px;
    --ap-space-16: 64px;
    --ap-space-20: 80px;
    --ap-space-24: 96px;
    --ap-space-32: 128px;
    --ap-space-40: 160px;

    /* Layout */
    --ap-container: 1440px;
    --ap-container-narrow: 1120px;
    --ap-container-reading: 720px;
    --ap-gutter-sm: 20px;
    --ap-gutter-md: 40px;
    --ap-gutter-lg: 64px;

    /* Radii — slightly larger for soft Anthropic feel */
    --ap-radius-xs:  2px;
    --ap-radius-sm:  4px;
    --ap-radius-md:  8px;
    --ap-radius-lg:  14px;
    --ap-radius-xl:  20px;
    --ap-radius-2xl: 28px;
    --ap-radius-pill: 999px;

    /* Shadows — subtle, paper-like */
    --ap-shadow-xs: 0 1px 2px rgba(25, 25, 24, 0.04);
    --ap-shadow-sm: 0 2px 4px rgba(25, 25, 24, 0.05);
    --ap-shadow-md: 0 4px 16px rgba(25, 25, 24, 0.06), 0 1px 3px rgba(25, 25, 24, 0.03);
    --ap-shadow-lg: 0 12px 32px rgba(25, 25, 24, 0.08);
    --ap-shadow-xl: 0 24px 56px rgba(25, 25, 24, 0.10);

    /* Gradient palette for abstract illustrations — green-based */
    --ap-gradient-halo: radial-gradient(ellipse 60% 80% at 50% 50%, rgba(77, 128, 94, 0.18) 0%, rgba(77, 128, 94, 0.05) 40%, transparent 70%);
    --ap-gradient-warm: linear-gradient(135deg, #EAF1EC 0%, #EFE5D4 50%, #FAF7F2 100%);
    --ap-gradient-deep: linear-gradient(135deg, #4D805E 0%, #2D4F38 100%);
    --ap-gradient-clay: linear-gradient(180deg, rgba(77, 128, 94, 0.12), rgba(196, 164, 126, 0.06) 50%, transparent);

    /* Motion */
    --ap-ease-smooth: cubic-bezier(0.22, 1, 0.36, 1);
    --ap-ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
    --ap-ease-in:     cubic-bezier(0.7, 0, 0.84, 0);
    --ap-duration-fast: 180ms;
    --ap-duration-base: 320ms;
    --ap-duration-slow: 600ms;
    --ap-duration-xslow: 1100ms;
}

/* Dark-panel override */
.ap-dark-panel {
    --ap-paper:         #1A1917;
    --ap-paper-raised:  #24221F;
    --ap-paper-sunk:    #12110F;
    --ap-border:        rgba(255, 255, 255, 0.08);
    --ap-border-strong: rgba(255, 255, 255, 0.14);
    --ap-divider:       rgba(255, 255, 255, 0.06);
    --ap-ink:           #F0EEE6;
    --ap-ink-2:         #D8D5CB;
    --ap-ink-3:         #9E9A8E;
    --ap-ink-4:         #6F6B60;
    color: var(--ap-ink);
    background: var(--ap-paper);
}

/* ─────────────────────────────────────────────────────────────────
 * BASE
 * ───────────────────────────────────────────────────────────────── */

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

body {
    background: var(--ap-paper);
    color: var(--ap-ink-2);
    font-family: var(--ap-font-sans);
    font-size: var(--ap-text-base);
    line-height: var(--ap-leading-body);
    font-feature-settings: "ss01", "cv11", "kern";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

::selection { background: var(--ap-accent-tint-2); color: var(--ap-ink); }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--ap-border-strong); border-radius: 8px; border: 2px solid var(--ap-paper); }
::-webkit-scrollbar-thumb:hover { background: var(--ap-ink-4); }

/* ─────────────────────────────────────────────────────────────────
 * TYPOGRAPHY — Editorial serif display, sans body
 * ───────────────────────────────────────────────────────────────── */

.ap-display {
    font-family: var(--ap-font-display);
    font-size: var(--ap-display);
    line-height: var(--ap-leading-display);
    letter-spacing: var(--ap-track-display);
    font-weight: 700;
    color: var(--ap-ink);
    margin: 0;
}

.ap-h1 {
    font-family: var(--ap-font-display);
    font-size: var(--ap-h1);
    line-height: var(--ap-leading-display);
    letter-spacing: var(--ap-track-display);
    font-weight: 700;
    color: var(--ap-ink);
    margin: 0;
}

.ap-h2 {
    font-family: var(--ap-font-display);
    font-size: var(--ap-h2);
    line-height: var(--ap-leading-tight);
    letter-spacing: var(--ap-track-display);
    font-weight: 700;
    color: var(--ap-ink);
    margin: 0;
}

.ap-h3 {
    font-family: var(--ap-font-display);
    font-size: var(--ap-h3);
    line-height: var(--ap-leading-heading);
    letter-spacing: var(--ap-track-heading);
    font-weight: 600;
    color: var(--ap-ink);
    margin: 0;
}

.ap-h4 {
    font-family: var(--ap-font-sans);
    font-size: var(--ap-h4);
    line-height: var(--ap-leading-heading);
    letter-spacing: var(--ap-track-tight);
    font-weight: 600;
    color: var(--ap-ink);
    margin: 0;
}

.ap-h5 { font-family: var(--ap-font-sans); font-size: var(--ap-h5); line-height: var(--ap-leading-heading); font-weight: 600; color: var(--ap-ink); margin: 0; }

.ap-lede {
    font-family: var(--ap-font-sans);
    font-size: var(--ap-text-lg);
    line-height: var(--ap-leading-prose);
    color: var(--ap-ink-3);
    font-weight: 400;
    max-width: 58ch;
}

.ap-body { color: var(--ap-ink-2); font-size: var(--ap-text-base); line-height: var(--ap-leading-body); }

/* Accent word — same geometric sans, green color (no italic switch) */
.ap-italic,
.ap-accent-word,
.hero-title em,
.ap-h1 em, .ap-h2 em, .ap-h3 em {
    color: var(--ap-accent);
    font-style: normal;   /* kill browser default italic */
    font-weight: inherit;
}

.ap-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--ap-font-mono);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: var(--ap-track-eyebrow);
    text-transform: uppercase;
    color: var(--ap-ink-4);
}
.ap-eyebrow::before {
    content: "";
    display: inline-block;
    width: 22px;
    height: 1px;
    background: var(--ap-accent);
}

a.ap-link {
    color: var(--ap-ink);
    text-decoration: none;
    background-image: linear-gradient(var(--ap-accent), var(--ap-accent));
    background-size: 100% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
    transition: background-size var(--ap-duration-base) var(--ap-ease-smooth),
                color var(--ap-duration-fast) var(--ap-ease-smooth);
}
a.ap-link:hover { color: var(--ap-accent); background-size: 0 1px; background-position: 100% 100%; }

/* ─────────────────────────────────────────────────────────────────
 * LAYOUT PRIMITIVES
 * ───────────────────────────────────────────────────────────────── */

.ap-container { width: 100%; max-width: var(--ap-container); margin: 0 auto; padding-left: var(--ap-gutter-sm); padding-right: var(--ap-gutter-sm); }
@media (min-width: 768px)  { .ap-container { padding-left: var(--ap-gutter-md); padding-right: var(--ap-gutter-md); } }
@media (min-width: 1280px) { .ap-container { padding-left: var(--ap-gutter-lg); padding-right: var(--ap-gutter-lg); } }

.ap-container-narrow  { max-width: var(--ap-container-narrow);  margin: 0 auto; padding: 0 var(--ap-gutter-md); }
.ap-container-reading { max-width: var(--ap-container-reading); margin: 0 auto; padding: 0 var(--ap-gutter-md); }

.ap-section { padding-top: var(--ap-space-24); padding-bottom: var(--ap-space-24); }
@media (min-width: 1024px) { .ap-section { padding-top: var(--ap-space-32); padding-bottom: var(--ap-space-32); } }

.ap-rule { height: 1px; background: var(--ap-border); border: 0; margin: 0; }

/* ─────────────────────────────────────────────────────────────────
 * COMPONENTS
 * ───────────────────────────────────────────────────────────────── */

.ap-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 24px;
    font-family: var(--ap-font-sans);
    font-size: var(--ap-text-base);
    font-weight: 500;
    letter-spacing: -0.005em;
    border-radius: var(--ap-radius-pill);
    border: 1px solid transparent;
    cursor: pointer;
    transition: all var(--ap-duration-base) var(--ap-ease-smooth);
    white-space: nowrap;
    text-decoration: none;
    line-height: 1;
    user-select: none;
}
.ap-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.ap-btn svg, .ap-btn i { width: 16px; height: 16px; flex-shrink: 0; }

.ap-btn-primary { background: var(--ap-ink); color: var(--ap-paper); border-color: var(--ap-ink); }
.ap-btn-primary:hover:not(:disabled) { background: var(--ap-ink-2); transform: translateY(-1px); }

.ap-btn-brand,
.ap-btn-accent { background: var(--ap-accent); color: #fff; border-color: var(--ap-accent); }
.ap-btn-brand:hover:not(:disabled),
.ap-btn-accent:hover:not(:disabled) { background: var(--ap-accent-dark); transform: translateY(-1px); }

.ap-btn-ghost { background: transparent; color: var(--ap-ink); border-color: var(--ap-border-strong); }
.ap-btn-ghost:hover:not(:disabled) { background: var(--ap-paper-raised); border-color: var(--ap-ink); }

.ap-btn-link {
    background: transparent; color: var(--ap-ink); padding: 8px 0;
    border-radius: 0; border-bottom: 1px solid var(--ap-ink); gap: 6px;
}
.ap-btn-link:hover:not(:disabled) { gap: 10px; color: var(--ap-accent); border-bottom-color: var(--ap-accent); }

.ap-btn-sm { padding: 10px 18px; font-size: var(--ap-text-sm); }
.ap-btn-lg { padding: 16px 28px; font-size: var(--ap-text-md); }

/* Cards */
.ap-card {
    background: var(--ap-paper-raised);
    border: 1px solid var(--ap-border);
    border-radius: var(--ap-radius-xl);
    padding: var(--ap-space-8);
    transition: all var(--ap-duration-base) var(--ap-ease-smooth);
}
.ap-card-hoverable:hover { border-color: var(--ap-border-strong); box-shadow: var(--ap-shadow-md); transform: translateY(-2px); }

/* Tag / Badge */
.ap-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    border-radius: var(--ap-radius-pill);
    font-family: var(--ap-font-mono);
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: var(--ap-track-eyebrow);
    text-transform: uppercase;
    background: var(--ap-paper-sunk);
    color: var(--ap-ink-3);
    border: 1px solid var(--ap-border);
}
.ap-tag-accent { background: var(--ap-accent-tint);  color: var(--ap-accent-darker); border-color: transparent; }
.ap-tag-brand  { background: var(--ap-accent-tint);  color: var(--ap-accent-darker); border-color: transparent; }
.ap-tag-forest { background: var(--ap-forest-tint);  color: var(--ap-forest);        border-color: transparent; }
.ap-tag-sand   { background: var(--ap-sand-tint);    color: var(--ap-clay);          border-color: transparent; }

/* Input */
.ap-input, .ap-textarea, .ap-select {
    width: 100%;
    padding: 12px 16px;
    background: var(--ap-paper-raised);
    border: 1px solid var(--ap-border);
    border-radius: var(--ap-radius-md);
    font-family: var(--ap-font-sans);
    font-size: var(--ap-text-base);
    color: var(--ap-ink);
    line-height: 1.4;
    transition: border-color var(--ap-duration-fast) var(--ap-ease-smooth),
                box-shadow var(--ap-duration-fast) var(--ap-ease-smooth);
}
.ap-input:focus, .ap-textarea:focus, .ap-select:focus {
    outline: none;
    border-color: var(--ap-accent);
    box-shadow: 0 0 0 3px var(--ap-accent-tint);
}
.ap-input::placeholder { color: var(--ap-ink-5); }

.ap-label { display: block; font-size: var(--ap-text-sm); font-weight: 500; color: var(--ap-ink-3); margin-bottom: 6px; }

/* Focus states */
a:focus-visible, button:focus-visible, [role="button"]:focus-visible {
    outline: 2px solid var(--ap-accent);
    outline-offset: 3px;
    border-radius: var(--ap-radius-xs);
}

/* Reveal */
.ap-reveal { opacity: 0; transform: translateY(24px); transition: opacity var(--ap-duration-xslow) var(--ap-ease-smooth), transform var(--ap-duration-xslow) var(--ap-ease-smooth); }
.ap-reveal.in-view { opacity: 1; transform: none; }

/* Stat */
.ap-stat-number {
    font-family: var(--ap-font-display);
    font-size: clamp(3rem, 6vw, 5rem);
    line-height: 1;
    letter-spacing: var(--ap-track-display);
    color: var(--ap-ink);
    font-weight: 400;
    font-variation-settings: "opsz" 96;
}
.ap-stat-label {
    font-family: var(--ap-font-mono);
    font-size: 0.6875rem;
    letter-spacing: var(--ap-track-eyebrow);
    text-transform: uppercase;
    color: var(--ap-ink-4);
    margin-top: 8px;
}
