/* ============================================================
   Atlas brand page — page-specific styles.
   Loaded by templates/brand.html only.

   Externalized from the inline <style> block on 2026-05-04.
   Selectors and rules are unchanged from the original; markup
   still references the same class names, so visual output is
   identical pre-externalization.

   Subsequent migration passes (logged in memory/TODO.md) move
   legacy classes here to the shared .f-* / .fm-* foundation
   in components.css / marketing.css and delete duplicates.
   ============================================================ */
:root {
            --accent: #00b0f1;
            --accent-hover: #009ad3;
            --bg: #ffffff;
            --bg-tint: #f4f6f9;
            --bg-soft: #fafafa;
            --bg-hover: #ebecef;
            --border-light: #eef0f3;
            --border: #e5e7eb;
            --border-strong: #d4d4d8;
            --border-dark: #71717a;
            --border-graphic: 5px solid;
            --text: #111827;
            --text-2: #525866;
            --text-muted: #9ca3af;
        }
        /* ---------- Logo grid ---------- */
        .logo-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 0.85rem;
        }
        @media (min-width: 720px) { .logo-grid { grid-template-columns: repeat(2, 1fr); } }
        @media (min-width: 1024px) { .logo-grid { grid-template-columns: repeat(3, 1fr); } }
        .logo-card {
            border: 1px solid var(--border-strong);
            background: #ffffff;
            border-radius: 22px;
            overflow: hidden;
            box-shadow: 0 12px 28px -16px rgba(15, 23, 42, 0.10), 0 2px 6px -3px rgba(15, 23, 42, 0.04);
            display: flex;
            flex-direction: column;
        }
        .logo-card-stage {
            height: 240px;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 2.25rem;
            position: relative;
            isolation: isolate;
            flex-shrink: 0;
            background: linear-gradient(180deg, #e2e4e9 0%, transparent 100%);
        }
        .logo-card-stage::before {
            content: '';
            position: absolute;
            inset: 0;
            background-image: radial-gradient(circle, rgba(15, 23, 42, 0.18) 1px, transparent 1.5px);
            background-size: 7px 7px;
            pointer-events: none;
            -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 18%, transparent 55%);
            mask-image: linear-gradient(180deg, #000 0%, #000 18%, transparent 55%);
            z-index: -1;
        }
        .logo-card-stage--dark {
            background: linear-gradient(180deg, #0a0a0a 0%, #141414 100%);
        }
        .logo-card-stage--dark::before {
            background-image: radial-gradient(circle, rgba(255, 255, 255, 0.10) 1px, transparent 1.5px);
            -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 18%, transparent 55%);
            mask-image: linear-gradient(180deg, #000 0%, #000 18%, transparent 55%);
        }
        .logo-card-stage--accent {
            background: linear-gradient(180deg, var(--accent) 0%, var(--accent-hover) 100%);
        }
        .logo-card-stage--accent::before {
            background-image: radial-gradient(circle, rgba(255, 255, 255, 0.20) 1px, transparent 1.5px);
        }
        .logo-card-stage img { width: 88px; height: 88px; max-width: 88px; max-height: 88px; object-fit: contain; }
        .logo-card-img--rounded { border-radius: 18px; }
        /* Pair layout — show two icon variants side-by-side inside one stage */
        .logo-card-stage--pair { gap: 1.5rem; }
        .logo-card-body {
            flex: 1;
            padding: 1.2rem 1.4rem 1.4rem;
            border-top: 1px solid var(--border-light);
            display: flex;
            flex-direction: column;
            align-items: flex-start;
            gap: 0.85rem;
        }
        .logo-card-actions {
            margin-top: auto;
            width: 100%;
            display: flex;
            gap: 0.45rem;
        }
        .logo-card-actions .logo-card-download { flex: 1; }
        .logo-card-info h3 {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 1rem;
            font-weight: 600;
            color: var(--text);
            letter-spacing: -0.01em;
        }
        .logo-card-info p {
            margin-top: 0.2rem;
            font-size: 0.84rem;
            color: var(--text-2);
            line-height: 1.4;
        }
        .logo-card-download {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.4rem;
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.82rem;
            font-weight: 600;
            color: #ffffff;
            background: linear-gradient(180deg, #1a1a1a 0%, #050505 100%);
            border: 0;
            padding: 0.6rem 1.05rem;
            border-radius: 0.65rem;
            transition: background 0.2s;
            white-space: nowrap;
        }
        .logo-card-download:hover {
            background: linear-gradient(180deg, #2a2a2a 0%, #0a0a0a 100%);
            color: #ffffff;
        }
        .logo-card-download svg {
            width: 12px; height: 12px;
            fill: none; stroke: currentColor;
            stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round;
        }

        /* ---------- Color palette ---------- */
        .color-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 0.85rem;
        }
        @media (min-width: 720px) { .color-grid { grid-template-columns: repeat(3, 1fr); } }
        @media (min-width: 1024px) { .color-grid { grid-template-columns: repeat(4, 1fr); } }
        .color-card {
            border: 1px solid var(--border-strong);
            background: #ffffff;
            border-radius: 22px;
            overflow: hidden;
            box-shadow: 0 12px 28px -16px rgba(15, 23, 42, 0.10), 0 2px 6px -3px rgba(15, 23, 42, 0.04);
        }
        .color-swatch {
            height: 140px;
            position: relative;
        }
        .color-swatch::after {
            content: '';
            position: absolute;
            left: 0; right: 0; bottom: 0;
            height: 1px;
            background: rgba(0, 0, 0, 0.05);
        }
        .color-info { padding: 1rem 1.15rem 1.2rem; }
        .color-info h3 {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.92rem;
            font-weight: 600;
            color: var(--text);
            letter-spacing: -0.01em;
        }
        .color-info code {
            display: inline-block;
            margin-top: 0.3rem;
            font-family: "SF Mono", "JetBrains Mono", ui-monospace, monospace;
            font-size: 0.78rem;
            color: var(--text-2);
            background: var(--bg-tint);
            padding: 2px 7px;
            border-radius: 6px;
            letter-spacing: 0;
        }
        .color-info p {
            margin-top: 0.6rem;
            font-size: 0.82rem;
            color: var(--text-2);
            line-height: 1.45;
        }

        /* ---------- Typography ---------- */
        .type-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 0.85rem;
        }
        @media (min-width: 880px) { .type-grid { grid-template-columns: repeat(3, 1fr); } }
        .type-card {
            border: 1px solid var(--border-strong);
            background: #ffffff;
            border-radius: 22px;
            padding: 1.85rem 1.75rem;
            display: flex;
            flex-direction: column;
            gap: 1rem;
            box-shadow: 0 12px 28px -16px rgba(15, 23, 42, 0.10), 0 2px 6px -3px rgba(15, 23, 42, 0.04);
        }
        .type-sample {
            height: 160px;
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
            font-size: clamp(2.6rem, 5vw, 3.4rem);
            line-height: 1;
            letter-spacing: -0.02em;
            color: var(--text);
        }
        .type-meta { flex: 1; }
        .type-sample-druk {
            font-family: "Druk Wide", "Mona Sans", sans-serif;
            font-weight: 700;
            text-transform: uppercase;
            font-size: clamp(1.4rem, 3vw, 1.85rem);
            letter-spacing: 0;
        }
        .type-sample-mona {
            font-family: "Mona Sans", Inter, sans-serif;
            font-weight: 700;
            letter-spacing: -0.025em;
        }
        .type-sample-inter {
            font-family: Inter, sans-serif;
            font-weight: 400;
            font-size: 1.1rem;
            line-height: 1.55;
            color: var(--text-2);
            letter-spacing: -0.01em;
        }
        .type-meta {
            border-top: 1px solid var(--border-light);
            padding-top: 1rem;
            display: flex;
            flex-direction: column;
            gap: 0.4rem;
        }
        .type-meta h3 {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 1rem;
            font-weight: 600;
            color: var(--text);
            letter-spacing: -0.01em;
        }
        .type-meta p {
            font-size: 0.86rem;
            color: var(--text-2);
            line-height: 1.5;
        }
        .type-tag {
            align-self: flex-start;
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.7rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--accent);
            background: rgba(0, 176, 241, 0.10);
            border: 1px solid rgba(0, 176, 241, 0.22);
            padding: 3px 9px;
            border-radius: 999px;
            margin-top: 0.35rem;
        }
        /* Type spec — compact key/value table beneath each typeface description */
        .type-spec {
            margin-top: 0.45rem;
            padding-top: 0.85rem;
            border-top: 1px dashed var(--border-light);
            display: flex;
            flex-direction: column;
            gap: 0.35rem;
        }
        .type-spec > div {
            display: flex;
            justify-content: space-between;
            gap: 0.6rem;
            font-size: 0.78rem;
            line-height: 1.4;
        }
        .type-spec dt {
            font-family: "Mona Sans", Inter, sans-serif;
            font-weight: 600;
            color: var(--text-2);
            letter-spacing: 0.02em;
            text-transform: uppercase;
            font-size: 0.7rem;
            white-space: nowrap;
            align-self: center;
        }
        .type-spec dd {
            margin: 0;
            font-family: "Mona Sans", Inter, sans-serif;
            font-feature-settings: "tnum" 1;
            color: var(--text);
            text-align: right;
        }

        /* ---------- Usage rules ---------- */
        .usage-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 0.85rem;
        }
        @media (min-width: 720px) { .usage-grid { grid-template-columns: repeat(2, 1fr); } }
        .usage-card {
            border: 1px solid var(--border-strong);
            background: #ffffff;
            border-radius: 22px;
            padding: 1.85rem 1.75rem;
            box-shadow: 0 12px 28px -16px rgba(15, 23, 42, 0.10), 0 2px 6px -3px rgba(15, 23, 42, 0.04);
        }
        .usage-card-head {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.74rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            margin-bottom: 0.85rem;
        }
        .usage-card--do .usage-card-head { color: #16a34a; }
        .usage-card--dont .usage-card-head { color: #dc2626; }
        .usage-card-head .usage-icon {
            width: 22px; height: 22px;
            border-radius: 50%;
            display: grid; place-items: center;
        }
        .usage-card--do .usage-icon { background: rgba(22, 163, 74, 0.10); border: 1px solid rgba(22, 163, 74, 0.22); }
        .usage-card--dont .usage-icon { background: rgba(220, 38, 38, 0.10); border: 1px solid rgba(220, 38, 38, 0.22); }
        .usage-icon svg { width: 12px; height: 12px; fill: none; stroke: currentColor; stroke-width: 2.6; stroke-linecap: round; stroke-linejoin: round; }
        .usage-card ul {
            display: flex;
            flex-direction: column;
            gap: 0.6rem;
        }
        .usage-card li {
            font-size: 0.95rem;
            color: var(--text-2);
            line-height: 1.55;
            position: relative;
            padding-left: 1.1rem;
        }
        .usage-card li::before {
            content: '';
            position: absolute;
            left: 0; top: 0.65rem;
            width: 5px; height: 5px;
            border-radius: 50%;
            background: var(--border-strong);
        }
        .usage-card--do li::before { background: #16a34a; }
        .usage-card--dont li::before { background: #dc2626; }

        /* ---------- End CTA ---------- */
        .end-cta {
            border: 1px solid var(--border-strong);
            background: #ffffff;
            border-radius: 22px;
            padding: 2.4rem 2rem;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 1.4rem;
            text-align: center;
            box-shadow: 0 12px 28px -16px rgba(15, 23, 42, 0.10), 0 2px 6px -3px rgba(15, 23, 42, 0.04);
        }
        @media (min-width: 720px) {
            .end-cta {
                flex-direction: row;
                justify-content: space-between;
                text-align: left;
                padding: 3rem 3rem;
            }
        }
        .end-cta-text { max-width: 520px; }
        .end-cta-text h2 {
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: clamp(1.55rem, 3vw, 2rem);
            font-weight: 600;
            color: var(--text);
            letter-spacing: -0.02em;
            margin: 0;
        }
        .end-cta-text p {
            margin-top: 0.6rem;
            font-size: 0.98rem;
            color: var(--text-2);
            line-height: 1.55;
        }
        .end-cta a.btn-hero-black {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.4rem;
            background: linear-gradient(180deg, #1a1a1a 0%, #050505 100%);
            color: #ffffff;
            font-family: "Mona Sans", Inter, sans-serif;
            font-size: 0.95rem;
            font-weight: 600;
            padding: 0.85rem 1.6rem;
            border-radius: 0.85rem;
            white-space: nowrap;
            transition: background 0.2s;
        }
        .end-cta a.btn-hero-black:hover { background: linear-gradient(180deg, #2a2a2a 0%, #0a0a0a 100%); }
