/* @docs tabs.css - profile header (Bloomberg/PitchBook style) + snapshot tiles + transparency dots, profile sticky anchor nav (.profile-nav), subsidiary cards, contact card grid, profile tab panes (.profile-section + .tab-active fade), industry-page tabs (.istp-tabs / .istp-tab). Loaded LAST in cascade so its desktop defaults (loaded after responsive.css mobile @media) continue to win on >900px and its own internal @media (max-width: 900px) block (.profile-snapshot 2-col, .profile-header padding, .profile-header-name font, .profile-nav top) continues to override responsive.css 768px rules on <=768px (last cascade wins). */

        /* ========= PROFILE HEADER (Bloomberg / PitchBook style) ========= */
        .profile-header {
            border: 1px solid var(--border-mid);
            border-radius: 10px;
            padding: 1.25rem 1.5rem 1.4rem;
            margin: 0.25rem 0 1.25rem;
            background: linear-gradient(180deg, #fbfaf8 0%, #ffffff 100%);
        }
        .profile-header-top {
            display: flex;
            align-items: flex-start;
            justify-content: space-between;
            gap: 1.5rem;
            flex-wrap: wrap;
            padding-bottom: 1rem;
            border-bottom: 1px solid var(--border-soft);
        }
        .profile-header-id { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
        .profile-header-name {
            font-size: 1.625rem; font-weight: 500; letter-spacing: -0.025em;
            color: var(--text-dark); line-height: 1.15;
        }
        .profile-header-sub {
            font-size: 13px; color: var(--text-dark-secondary);
            letter-spacing: -0.005em;
        }
        .profile-header-sub a { color: var(--text-dark-secondary); }
        .profile-header-sub a:hover { color: var(--text-dark); }
        .profile-header-tags { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

        .profile-transparency {
            display: inline-flex; align-items: center; gap: 8px;
            padding: 6px 10px; border: 1px solid var(--border-mid);
            border-radius: 6px; background: #fff;
            font-size: 11.5px; color: var(--text-dark-secondary);
            letter-spacing: 0.04em; text-transform: uppercase;
        }
        .profile-transparency-dots { display: inline-flex; gap: 3px; }
        .profile-transparency-dot {
            width: 7px; height: 7px; border-radius: 50%;
            background: var(--border-mid);
        }
        .profile-transparency-dot.filled { background: #4f6240; }
        .profile-transparency-score {
            font-weight: 500; color: var(--text-dark); letter-spacing: 0;
            text-transform: none; font-size: 12px;
        }

        .profile-snapshot {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 1px;
            margin-top: 1rem;
            background: var(--border-soft);
            border: 1px solid var(--border-soft);
            border-radius: 6px;
            overflow: hidden;
        }
        .profile-snap-tile {
            background: #fff;
            padding: 0.75rem 0.95rem;
            min-width: 0;
        }
        .profile-snap-label {
            font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
            color: var(--text-dark-tertiary); font-weight: 500; margin-bottom: 4px;
        }
        .profile-snap-value {
            font-size: 14px; color: var(--text-dark); line-height: 1.3;
            font-weight: 450; letter-spacing: -0.01em;
            word-wrap: break-word; overflow-wrap: break-word;
        }
        .profile-snap-value-sub {
            font-size: 11.5px; color: var(--text-dark-tertiary); margin-top: 2px;
        }

        /* ========= PROFILE STICKY ANCHOR NAV ========= */
        .profile-nav {
            position: sticky;
            top: 53px; /* topbar height */
            z-index: 5;
            display: flex;
            gap: 2px;
            overflow-x: auto;
            background: rgba(255,255,255,0.96);
            backdrop-filter: blur(6px);
            -webkit-backdrop-filter: blur(6px);
            border-bottom: 1px solid var(--border-soft);
            margin: 0 -1rem 1.5rem;
            padding: 0 1rem;
            scrollbar-width: none;
        }
        .profile-nav::-webkit-scrollbar { display: none; }
        .profile-nav a {
            display: inline-flex; align-items: center;
            padding: 0.7rem 0.9rem;
            font-size: 12.5px;
            color: var(--text-dark-secondary);
            letter-spacing: -0.005em;
            text-decoration: none;
            white-space: nowrap;
            border-bottom: 2px solid transparent;
            transition: color 0.15s ease, border-color 0.15s ease;
        }
        .profile-nav a:hover { color: var(--text-dark); }
        .profile-nav a.active {
            color: var(--text-dark);
            border-bottom-color: var(--text-dark);
            font-weight: 500;
        }

        /* ========= SUBSIDIARY CARDS ========= */
        .subsidiary-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 0.75rem;
            margin: 0.75rem 0 1.5rem;
        }
        .subsidiary-card {
            border: 1px solid var(--border-soft);
            border-radius: 8px;
            padding: 1rem 1.1rem 1.1rem;
            background: #fff;
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
            transition: border-color 0.15s ease;
        }
        .subsidiary-card:hover { border-color: var(--border-mid); }
        .subsidiary-card-head {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 0.75rem;
            min-height: 32px;
        }
        .subsidiary-card-logo {
            max-height: 28px;
            max-width: 130px;
            object-fit: contain;
            filter: grayscale(0.15);
        }
        .subsidiary-card-name {
            font-size: 15px;
            font-weight: 500;
            color: var(--text-dark);
            letter-spacing: -0.01em;
        }
        .subsidiary-card-tag {
            font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
            color: var(--text-dark-tertiary); font-weight: 500;
        }
        .subsidiary-card-desc {
            font-size: 13px;
            color: var(--text-dark-secondary);
            line-height: 1.5;
            margin: 0;
        }
        .subsidiary-card-meta {
            display: flex;
            gap: 1rem;
            font-size: 11.5px;
            color: var(--text-dark-tertiary);
            letter-spacing: 0.04em;
            text-transform: uppercase;
            padding-top: 0.4rem;
            border-top: 1px solid var(--border-soft);
            margin-top: auto;
        }
        .subsidiary-card-meta strong {
            color: var(--text-dark);
            font-weight: 500;
            letter-spacing: 0;
            text-transform: none;
            font-size: 12.5px;
            display: block;
            margin-top: 2px;
        }
        @media (max-width: 720px) {
            .subsidiary-grid { grid-template-columns: 1fr; }
        }

        /* ========= CONTACT CARD ========= */
        .contact-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 1px;
            background: var(--border-soft);
            border: 1px solid var(--border-soft);
            border-radius: 8px;
            overflow: hidden;
            margin: 0.6rem 0 1.5rem;
        }
        .contact-col { background: #fff; display: flex; flex-direction: column; }
        .contact-block {
            padding: 0.9rem 1.1rem;
            border-bottom: 1px solid var(--border-soft);
        }
        .contact-block:last-child { border-bottom: none; }
        .contact-block-label {
            font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
            color: var(--text-dark-tertiary); font-weight: 500;
            margin-bottom: 0.55rem;
        }
        .contact-block-primary {
            font-size: 14px; color: var(--text-dark);
            font-weight: 450; letter-spacing: -0.005em;
            margin-bottom: 0.4rem;
        }
        .contact-row {
            display: flex; align-items: center; gap: 8px;
            font-size: 13px; color: var(--text-dark);
            padding: 3px 0;
            line-height: 1.4;
        }
        .contact-row svg {
            flex-shrink: 0;
            color: var(--text-dark-tertiary);
            width: 13px; height: 13px;
        }
        .contact-row a { color: var(--text-dark); text-decoration: none; }
        .contact-row a:hover { text-decoration: underline; text-decoration-color: rgba(26,26,26,0.4); text-underline-offset: 2px; }
        .contact-row-handle { color: var(--text-dark-tertiary); margin-left: 4px; font-size: 12.5px; }
        .contact-row-muted { color: var(--text-dark-secondary); }
        .contact-row-link-out {
            font-size: 12px; color: var(--text-dark-tertiary);
            padding-top: 4px;
        }
        .contact-row-link-out a { color: var(--text-dark-tertiary); }
        .contact-row-link-out a:hover { color: var(--text-dark); }

        @media (max-width: 720px) {
            .contact-grid { grid-template-columns: 1fr; }
        }

        /* ========= PROFILE TAB PANES ========= */
        .profile-section {
            padding-top: 0.75rem;
        }
        .profile-section[id^="sec-"] { display: none; }
        .profile-section[id^="sec-"].tab-active {
            display: block;
            animation: tabFadeIn 0.22s ease-out;
        }
        @keyframes tabFadeIn {
            from { opacity: 0; transform: translateY(4px); }
            to   { opacity: 1; transform: none; }
        }
        .profile-section-label {
            font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase;
            color: var(--text-dark-tertiary); font-weight: 500;
            margin-bottom: 0.25rem;
        }
        .profile-section > h2:first-of-type,
        .profile-section > .profile-section-label + h2 {
            margin-top: 0.25rem;
        }

        @media (max-width: 900px) {
            .profile-snapshot { grid-template-columns: repeat(2, 1fr); }
            .profile-header { padding: 1rem 1.1rem 1.15rem; }
            .profile-header-name { font-size: 1.375rem; }
            .profile-nav { top: 49px; }
        }

        /* Unified industry-page tab styling (matches ISTP look across all 6 new industries) */
        .istp-tabs {
            display: flex;
            gap: 0;
            border-bottom: 1px solid var(--border-soft, var(--rule));
            margin: 1.5rem 0;
        }
        .istp-tab {
            background: none;
            border: none;
            padding: 0.75rem 1.25rem;
            font-family: inherit;
            font-size: 14px;
            font-weight: 500;
            color: var(--text-dark-secondary);
            cursor: pointer;
            border-bottom: 2px solid transparent;
            margin-bottom: -1px;
        }
        .istp-tab.active,
        .istp-tab:hover {
            color: var(--text-dark);
        }
        .istp-tab.active {
            border-bottom-color: var(--text-dark);
        }

