/*!
 * nicklaunches.css — Reusable design system pack
 * Mirrors the next-app design tokens exactly (OKLCH values, shadows, fonts).
 * Neo-brutalist: 2px black borders, hard 2px-2px-0 shadows, orange accent.
 *
 * No build step. Drop into any static project, link via:
 *   <link rel="stylesheet" href="nicklaunches.css">
 *
 * Includes:
 *   - Design tokens (CSS custom properties)
 *   - Base typography (DM Sans body, 900-weight headings)
 *   - Utilities (mirrors most-used Tailwind classes from the source app)
 *   - Component primitives: .nl-btn, .nl-card, .nl-badge, .nl-input,
 *     .nl-table, .nl-page-header, .nl-hero, .nl-breadcrumb, .nl-section
 */

/* =====================================================
   Design tokens
   ===================================================== */
:root {
    --background: oklch(95.38% 0.0357 72.89);
    --secondary-background: oklch(100% 0 0);
    --foreground: oklch(0% 0 0);
    --main-foreground: oklch(0% 0 0);
    --main: oklch(72.27% 0.1894 50.19);
    --border: oklch(0% 0 0);
    --ring: oklch(0% 0 0);
    --overlay: oklch(0% 0 0 / 0.8);
    --shadow: 2px 2px 0 0 var(--border);
    --shadow-lg: 4px 4px 0 0 var(--border);

    --chart-1: #ff7a05;
    --chart-2: #0099ff;
    --chart-3: #ffbf00;
    --chart-4: #8bd600;
    --chart-5: #7a83ff;

    --radius-base: 6px;
    --radius-pill: 9999px;

    --spacing-box-x: 2px;
    --spacing-box-y: 2px;

    --font-sans:
        "DM Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
        "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji",
        "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
        "Courier New", monospace;

    --weight-base: 500;
    --weight-heading: 900;
}

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

html {
    background: var(--secondary-background);
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    background: var(--background);
    color: var(--foreground);
    font-family: var(--font-sans);
    font-weight: var(--weight-base);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: var(--weight-heading);
    line-height: 1.15;
    margin: 0 0 0.5em;
}

p {
    margin: 0 0 1em;
}

a {
    color: inherit;
    text-decoration: none;
}

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

button {
    font-family: inherit;
    font-weight: inherit;
    color: inherit;
    background: none;
    border: 0;
    padding: 0;
    cursor: pointer;
}

input, select, textarea {
    font-family: inherit;
    font-size: inherit;
    color: inherit;
}

/* Custom scrollbar (matches the source app exactly) */
* {
    scrollbar-width: thin;
    scrollbar-color: #c9c9c9 #e5e5e5;
}
::-webkit-scrollbar {
    width: 14px;
    height: 14px;
}
::-webkit-scrollbar-track {
    background: #e5e5e5;
    border-left: 2px solid var(--border);
}
::-webkit-scrollbar-thumb {
    background: #c9c9c9;
    border: 2px solid var(--border);
}
::-webkit-scrollbar-thumb:hover { background: #b0b0b0; }
::-webkit-scrollbar-thumb:active { background: #999; }
::-webkit-scrollbar-corner { background: var(--background); }

/* =====================================================
   Layout helpers
   ===================================================== */
.nl-container {
    width: 100%;
    margin-inline: auto;
    padding-inline: 1rem;
    max-width: 72rem; /* 6xl */
}
@media (min-width: 640px) { .nl-container { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .nl-container { padding-inline: 2rem; } }

.nl-section { margin-block: 4rem; }
.nl-section--tight { margin-block: 2rem; }

/* =====================================================
   Typography utilities
   ===================================================== */
.nl-heading { font-weight: var(--weight-heading); line-height: 1.1; }
.nl-text-muted { color: color-mix(in srgb, var(--foreground) 70%, transparent); }
.nl-text-dim { color: color-mix(in srgb, var(--foreground) 60%, transparent); }
.nl-text-mono { font-family: var(--font-mono); }
.nl-text-uppercase { text-transform: uppercase; letter-spacing: 0.05em; }
.nl-text-accent { color: var(--main); }

/* =====================================================
   Underline accent (replaces the HandDrawnUnderline component)
   ===================================================== */
.nl-underline {
    background-image: linear-gradient(transparent 60%, color-mix(in srgb, var(--main) 40%, transparent) 60%);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    padding: 0 0.1em;
}

/* =====================================================
   Buttons (.nl-btn)
   Behavior: solid border + 2px hard shadow → hover translates,
             shadow collapses (signature neo-brutalist tap).
   ===================================================== */
.nl-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    font-weight: var(--weight-heading);
    font-size: 0.9375rem;
    line-height: 1.2;
    border: 2px solid var(--border);
    border-radius: var(--radius-base);
    background: var(--secondary-background);
    color: var(--foreground);
    box-shadow: var(--shadow);
    transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease;
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
}
.nl-btn:hover {
    transform: translate(var(--spacing-box-x), var(--spacing-box-y));
    box-shadow: none;
}
.nl-btn:active {
    transform: translate(var(--spacing-box-x), var(--spacing-box-y));
    box-shadow: none;
}
.nl-btn:focus-visible {
    outline: 2px solid var(--ring);
    outline-offset: 3px;
}

.nl-btn--primary {
    background: var(--main);
    color: var(--main-foreground);
}
.nl-btn--ghost {
    background: transparent;
    box-shadow: none;
    border-color: transparent;
}
.nl-btn--ghost:hover {
    background: color-mix(in srgb, var(--main) 10%, transparent);
    transform: none;
    box-shadow: none;
}
.nl-btn--sm {
    padding: 0.4rem 0.75rem;
    font-size: 0.8125rem;
}
.nl-btn--lg {
    padding: 0.85rem 1.5rem;
    font-size: 1.0625rem;
}
.nl-btn--block { width: 100%; justify-content: center; }

/* =====================================================
   Card (.nl-card)
   ===================================================== */
.nl-card {
    background: var(--secondary-background);
    border: 2px solid var(--border);
    border-radius: var(--radius-base);
    box-shadow: var(--shadow);
    padding: 1.25rem;
    transition: transform 200ms ease, box-shadow 200ms ease;
}
.nl-card--link {
    display: block;
    cursor: pointer;
}
.nl-card--link:hover {
    transform: translate(var(--spacing-box-x), var(--spacing-box-y));
    box-shadow: none;
}
.nl-card--accent {
    background: var(--main);
    color: var(--main-foreground);
    border-width: 4px;
    padding: 2rem;
}
.nl-card--featured {
    background: #fefce8; /* amber-50 */
}
.nl-card--lg { padding: 2rem; }
@media (min-width: 1024px) { .nl-card--lg { padding: 3rem; } }

/* =====================================================
   Badges (.nl-badge)
   Maps to focus/pricing/linkType pills used in directory listings.
   ===================================================== */
.nl-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1.2;
    border-radius: var(--radius-base);
    background: var(--main);
    color: var(--main-foreground);
    border: 1px solid transparent;
}
.nl-badge--outline {
    background: color-mix(in srgb, var(--main) 20%, transparent);
    color: var(--foreground);
    border-color: var(--main);
}
.nl-badge--soon {
    background: color-mix(in srgb, var(--main) 20%, transparent);
    color: var(--foreground);
    border-color: var(--main);
    font-size: 0.625rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

/* Color variants (mirrors pricingConfig/focusConfig palette) */
.nl-badge--blue { background: #3b82f6; color: #fff; }
.nl-badge--purple { background: #a855f7; color: #fff; }
.nl-badge--orange { background: #f97316; color: #fff; }
.nl-badge--amber { background: #f59e0b; color: #000; }
.nl-badge--emerald { background: #059669; color: #fff; }
.nl-badge--teal { background: #0d9488; color: #fff; }
.nl-badge--slate { background: #64748b; color: #fff; }
.nl-badge--indigo { background: #6366f1; color: #fff; }
.nl-badge--pink { background: #ec4899; color: #fff; }

/* =====================================================
   Inputs (.nl-input, .nl-select)
   ===================================================== */
.nl-input,
.nl-select {
    width: 100%;
    padding: 0.625rem 0.875rem;
    background: var(--secondary-background);
    border: 2px solid var(--border);
    border-radius: var(--radius-base);
    box-shadow: var(--shadow);
    font-weight: var(--weight-base);
    line-height: 1.3;
    color: var(--foreground);
    transition: transform 150ms ease, box-shadow 150ms ease;
}
.nl-input:focus,
.nl-select:focus {
    outline: none;
    transform: translate(var(--spacing-box-x), var(--spacing-box-y));
    box-shadow: none;
}
.nl-input::placeholder {
    color: color-mix(in srgb, var(--foreground) 50%, transparent);
}
.nl-select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 16px;
    padding-right: 2.25rem;
}

.nl-label {
    display: block;
    font-weight: var(--weight-heading);
    font-size: 0.8125rem;
    margin-bottom: 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* =====================================================
   Table (.nl-table) — used for directory listings
   ===================================================== */
.nl-table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-base);
    border: 2px solid var(--border);
}
.nl-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--secondary-background);
}
.nl-table thead {
    background: color-mix(in srgb, var(--main) 10%, transparent);
    border-bottom: 2px solid var(--border);
}
.nl-table th {
    text-align: left;
    padding: 0.75rem 1rem;
    font-weight: var(--weight-heading);
    font-size: 0.875rem;
}
.nl-table td {
    padding: 0.875rem 1rem;
    border-top: 2px solid var(--border);
    vertical-align: top;
}
.nl-table tbody tr:first-child td {
    border-top: 0;
}
.nl-table tbody tr {
    transition: background 150ms ease;
}
.nl-table tbody tr:hover {
    background: color-mix(in srgb, var(--main) 5%, transparent);
}
.nl-table tr.nl-row--featured {
    background: #fefce8;
}
.nl-table tr.nl-row--featured:hover {
    background: #fef3c7;
}

/* Avatar bubble used in tables/lists */
.nl-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-pill);
    background: color-mix(in srgb, var(--main) 20%, transparent);
    border: 2px solid var(--border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--weight-heading);
    overflow: hidden;
    flex-shrink: 0;
}
.nl-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nl-avatar--has-logo { background: #fff; }
.nl-avatar--fallback {
    background: color-mix(in srgb, var(--main) 20%, transparent);
    font-size: 0.875rem;
    color: var(--foreground);
}

/* =====================================================
   Page header (.nl-page-header) — mirrors the PageHeader component
   ===================================================== */
.nl-page-header {
    margin-block: 2.5rem 3rem;
}
.nl-page-header h1 {
    font-size: clamp(2rem, 5vw, 3.25rem);
}
.nl-page-header .nl-page-desc {
    font-size: 1.0625rem;
    max-width: 42rem;
    color: color-mix(in srgb, var(--foreground) 80%, transparent);
    margin-top: 0.5rem;
}

/* Hero / accent banner */
.nl-hero {
    background: var(--main);
    color: var(--main-foreground);
    border: 4px solid var(--border);
    box-shadow: var(--shadow);
    border-radius: var(--radius-base);
    padding: 2rem;
}
@media (min-width: 1024px) {
    .nl-hero { padding: 3rem; }
}
.nl-hero h2 { font-size: clamp(1.5rem, 3.2vw, 2rem); margin-bottom: 0.5rem; }
.nl-hero p {
    color: color-mix(in srgb, var(--main-foreground) 90%, transparent);
    font-size: 1.0625rem;
    max-width: 38rem;
}

/* =====================================================
   Breadcrumbs (.nl-breadcrumb)
   ===================================================== */
.nl-breadcrumb {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    font-size: 0.875rem;
    color: color-mix(in srgb, var(--foreground) 70%, transparent);
    margin-bottom: 1.25rem;
}
.nl-breadcrumb a:hover { color: var(--main); text-decoration: underline; }
.nl-breadcrumb-sep { opacity: 0.5; }

/* =====================================================
   Filter pills row (.nl-filter-row, .nl-pill)
   ===================================================== */
.nl-filter-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}
.nl-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.75rem;
    font-weight: var(--weight-heading);
    font-size: 0.8125rem;
    line-height: 1.2;
    border: 2px solid var(--border);
    border-radius: var(--radius-base);
    background: var(--secondary-background);
    box-shadow: var(--shadow);
    cursor: pointer;
    transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease;
}
.nl-pill:hover {
    transform: translate(var(--spacing-box-x), var(--spacing-box-y));
    box-shadow: none;
}
.nl-pill[aria-pressed="true"],
.nl-pill.is-active {
    background: var(--main);
    color: var(--main-foreground);
}

/* =====================================================
   Grid helpers (most common in the source app)
   ===================================================== */
.nl-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
}
@media (min-width: 640px) { .nl-grid--2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 768px) { .nl-grid--3 { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .nl-grid--4 { grid-template-columns: repeat(4, 1fr); } }
.nl-stack { display: flex; flex-direction: column; gap: 1rem; }
.nl-row { display: flex; gap: 0.75rem; align-items: center; flex-wrap: wrap; }
.nl-row--between { justify-content: space-between; }

/* =====================================================
   Misc small utilities (single-purpose, sparingly used)
   ===================================================== */
.nl-mt-0 { margin-top: 0; } .nl-mt-1 { margin-top: 0.5rem; } .nl-mt-2 { margin-top: 1rem; }
.nl-mt-4 { margin-top: 2rem; } .nl-mt-8 { margin-top: 4rem; }
.nl-mb-0 { margin-bottom: 0; } .nl-mb-1 { margin-bottom: 0.5rem; } .nl-mb-2 { margin-bottom: 1rem; }
.nl-mb-4 { margin-bottom: 2rem; } .nl-mb-8 { margin-bottom: 4rem; }
.nl-hidden { display: none; }
@media (max-width: 767px) { .nl-hidden-mobile { display: none; } }
@media (min-width: 768px) { .nl-hidden-desktop { display: none; } }
.nl-truncate {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Empty state */
.nl-empty {
    background: var(--secondary-background);
    border: 2px solid var(--border);
    border-radius: var(--radius-base);
    padding: 3rem 1rem;
    text-align: center;
}
.nl-empty h3 { font-size: 1.125rem; margin-bottom: 0.25rem; }
.nl-empty p { font-size: 0.875rem; color: color-mix(in srgb, var(--foreground) 60%, transparent); margin: 0; }

/* Site shell footer link group */
.nl-link {
    color: var(--main);
    font-weight: var(--weight-heading);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}
.nl-link:hover { text-decoration: underline; }
