/*
Theme Name: GCC AI Club Theme
Description: Cinematic AI/Data talent landing page with Three.js 3D visualizations
Author: Shivang Gupta / SG Consulting
Version: 2.1
*/

/* Font loading moved to header.php for performance (non-blocking) */

/* ==================== RESET & BASE ==================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
    width: 100%;
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--font-body, 'Poppins', 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif);
    background: var(--color-bg-primary);
    color: var(--color-text-primary);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    width: 100%;
    max-width: 100vw;
    min-height: 100vh;
    overflow-x: hidden;
}

body.gcc-modal-open {
    overflow: hidden;
}

/* Hide All Scrollbars - Content still scrolls */
::-webkit-scrollbar {
    width: 0px;
    height: 0px;
    display: none;
}

/* Firefox - Hide Scrollbar */
* {
    scrollbar-width: none;
}

/* IE/Edge - Hide Scrollbar */
html {
    -ms-overflow-style: none;
}

/* Scroll Progress Line */
.gcc-scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 2px;
    background: var(--hi-blue, #2563EB);
    width: 0%;
    z-index: 2000;
}

/* Legacy variables - kept for backwards compatibility, mapped to new theme system */
:root {
    --hi-text-primary: var(--color-text-primary);
    --hi-text-muted: var(--color-text-muted);
    --hi-border: var(--color-border-primary);
    --hi-surface: var(--color-surface);
    --hi-surface-dark: var(--color-bg-secondary);
    --hi-surface-dark-alt: var(--color-surface-elevated);
    --hi-glow-cyan: var(--glow-cyan);
    --hi-glow-purple: var(--glow-purple);
    --hi-glow-green: var(--glow-green);
    --hi-card-gradient: var(--card-gradient);
    --hi-card-border: var(--card-border);
    --hi-card-shadow: var(--card-shadow);
    --hi-motion-gentle: var(--motion-gentle);
    --hi-motion-medium: var(--motion-medium);
    --hi-motion-border: var(--motion-border);
    --hi-motion-panel: var(--motion-panel);
}

/* ==================== ANIMATED BACKGROUND (removed for light mode) ==================== */
.gcc-animated-bg,
.gcc-bg-orb,
.gcc-bg-orb-purple,
.gcc-bg-orb-cyan {
    display: none;
}

/* ==================== UNIFIED LAYOUT SYSTEM ==================== */
/* Container utilities for consistent width and alignment */
.hi-container,
.gcc-container {
    max-width: var(--container-max-width);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
    width: 100%;
}

.hi-container--narrow {
    max-width: var(--content-max-width);
}

.hi-container--full {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
}

/* Section spacing utilities */
.hi-section {
    padding-top: var(--section-spacing);
    padding-bottom: var(--section-spacing);
}

.hi-section--sm {
    padding-top: 40px;
    padding-bottom: 40px;
}

.hi-section--lg {
    padding-top: 120px;
    padding-bottom: 120px;
}

/* Card grid utilities */
.hi-grid {
    display: grid;
    gap: var(--card-spacing);
}

.hi-grid--2 {
    grid-template-columns: repeat(2, 1fr);
}

.hi-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

.hi-grid--auto {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

/* Responsive breakpoints */
@media (max-width: 1440px) {
    :root {
        --container-max-width: 1200px;
    }
}

@media (max-width: 1024px) {
    :root {
        --container-padding: 20px;
        --section-spacing: 60px;
        --card-spacing: 20px;
    }
    
    .hi-grid--3 {
        grid-template-columns: repeat(2, 1fr);
    }

    .hi-single-hero-inner {
        padding: 40px 30px 48px;
    }
}

@media (max-width: 768px) {
    :root {
        --container-padding: 16px;
        --section-spacing: 48px;
        --card-spacing: 16px;
    }
    
    .hi-grid--2,
    .hi-grid--3 {
        grid-template-columns: 1fr;
    }
    
    .hi-section {
        padding-top: 48px;
        padding-bottom: 48px;
    }
    
    .hi-section--lg {
        padding-top: 80px;
        padding-bottom: 80px;
    }

    .hi-single-hero {
        padding: 120px 0 80px;
    }

    .hi-single-hero-inner {
        padding: 32px 24px 40px;
    }

    .hi-hero-data-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    :root {
        --container-padding: 16px;
        --section-spacing: 40px;
    }

    .hi-single-hero {
        padding: 100px 0 70px;
    }

    .hi-hero-pill-row {
        flex-direction: column;
        gap: 8px;
    }
}

/* ==================== SECTION THEMING ==================== */
.gcc-section-light, .gcc-section-dark {
    position: relative;
    background: transparent;
    color: var(--color-text-primary);
    transition: var(--theme-transition);
}

/* Hero keeps its navy background — the generic section-light rule must NOT nuke it */
.gcc-hero.gcc-section-light {
    background: var(--hi-navy, #0D1B2A) !important;
    color: #FFFFFF;
}

.gcc-section-light::before { display: none; }

.gcc-section-title, .gcc-engine-title {
    font-family: var(--font-display, 'Sora', sans-serif);
    color: var(--color-text-primary);
    font-weight: 800;
    letter-spacing: -0.04em;
}

.gcc-growth-subtitle,
.gcc-feature-text p,
.gcc-impact-label,
.gcc-subtitle {
    color: var(--color-text-secondary, #475569);
    font-weight: 400;
}

.gcc-section-label {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    color: var(--hi-blue, #2563EB);
    font-weight: 500;
    letter-spacing: 0.12em;
    font-size: 12px;
    text-transform: uppercase;
    margin-bottom: 20px;
}

/* ==================== SITE HEADER — `.hi-home-nav` (unified, v3) ====================
   The home page was previously the only page with the elegant `.hi-home-nav`
   header. We've promoted that nav to the site header (rendered by header.php)
   so every page uses the exact same chrome. These styles are a self-contained
   copy (no --hi-* token dependency) used by pages that DO NOT load home-page.css.
   On the home page, home-page.css (loaded after style.css) overrides with its
   scoped `body.hi-home-active` rules — so that experience is unchanged.

   Legacy `.gcc-header` markup has been removed from header.php; keeping the old
   selectors (.gcc-header-*, .gcc-nav, .gcc-logo-*, .gcc-cta-btn) below as dead
   styles is harmless and safer than a mass delete. */
.hi-home-nav {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    padding: 18px 48px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: rgba(248, 250, 252, 0.85);
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 1px 0 rgba(15, 23, 42, 0.02);
    font-family: 'Poppins', 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}
/* Admin bar offset so sticky header sits below WP admin bar when logged in. */
body.admin-bar .hi-home-nav { top: 32px; }
@media (max-width: 782px) {
    body.admin-bar .hi-home-nav { top: 46px; }
}

/* Logo */
.hi-home-nav .hi-logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: #0f172a;
}
.hi-home-nav .hi-logo-mark {
    width: 36px; height: 36px;
    background: linear-gradient(135deg, #0070f3, #005bb5);
    border: 1px solid rgba(0, 112, 243, 0.4);
    border-radius: 8px;
    display: grid;
    place-items: center;
    font-family: 'Inter', 'Poppins', sans-serif;
    font-size: 11px;
    font-weight: 600;
    color: #fff;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}
.hi-home-nav .hi-logo-text {
    font-family: 'Poppins', 'Inter', sans-serif;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: #0f172a;
}
.hi-home-nav .hi-logo-text span { color: #0070f3; }

/* Primary nav links (centered) */
.hi-home-nav .hi-nav-links {
    display: flex;
    align-items: center;
    gap: 36px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.hi-home-nav .hi-nav-links li { margin: 0; padding: 0; }
.hi-home-nav .hi-nav-links a {
    font-family: 'Inter', 'Poppins', sans-serif;
    font-size: 12px;
    letter-spacing: 0.08em;
    color: #475569;
    font-weight: 500;
    text-decoration: none;
    text-transform: uppercase;
    transition: color 0.2s ease;
}
.hi-home-nav .hi-nav-links a:hover,
.hi-home-nav .hi-nav-links .current-menu-item a,
.hi-home-nav .hi-nav-links a.active { color: #0070f3; }

/* Right-side actions */
.hi-home-nav .hi-nav-actions {
    display: flex;
    gap: 12px;
    align-items: center;
}
.hi-home-nav .hi-nav-user {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', 'Poppins', sans-serif;
    font-size: 12px;
    letter-spacing: 0.06em;
    color: #475569;
    text-decoration: none;
}
.hi-home-nav .hi-nav-user-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #0070f3;
    box-shadow: 0 0 10px rgba(0, 112, 243, 0.5);
}

/* Buttons (used inside the nav) */
.hi-home-nav .hi-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 22px;
    border-radius: 6px;
    font-family: 'Inter', 'Poppins', sans-serif;
    font-size: 12px;
    letter-spacing: 0.06em;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    border: 1px solid transparent;
    white-space: nowrap;
    line-height: 1;
}
.hi-home-nav .hi-btn-ghost {
    background: transparent;
    color: #475569;
    border-color: rgba(15, 23, 42, 0.08);
}
.hi-home-nav .hi-btn-ghost:hover {
    color: #0f172a;
    border-color: rgba(15, 23, 42, 0.25);
    background: #ffffff;
}
.hi-home-nav .hi-btn-primary {
    background: linear-gradient(135deg, #0070f3, #005bb5);
    border-color: rgba(0, 112, 243, 0.3);
    color: #fff;
    box-shadow: 0 4px 14px rgba(0, 112, 243, 0.18);
}
.hi-home-nav .hi-btn-primary:hover {
    box-shadow: 0 6px 22px rgba(0, 112, 243, 0.28);
    border-color: #0070f3;
    transform: translateY(-1px);
}

@media (max-width: 900px) {
    .hi-home-nav { padding: 16px 24px; }
    .hi-home-nav .hi-nav-links { display: none; }
}

.gcc-header-container {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 32px;
}

.gcc-nav {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

.gcc-nav-list {
    list-style: none;
    display: flex;
    gap: 32px;
    align-items: center;
    margin: 0;
    padding: 0;
}

.gcc-nav-item a {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-secondary, #475569);
    text-decoration: none;
    padding: 6px 0;
    border-bottom: 1.5px solid transparent;
    transition: color 0.2s ease, border-color 0.2s ease;
}

.gcc-nav-item a:hover,
.gcc-nav-item a:focus {
    color: var(--color-primary, #0070f3);
}
.gcc-nav-item.current-menu-item a,
.gcc-nav-item a.active {
    color: var(--color-primary, #0070f3);
    border-bottom-color: var(--color-primary, #0070f3);
}

.gcc-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    transition: transform 0.3s ease;
}

.gcc-logo:hover { transform: scale(1.05); }

.gcc-logo-text {
    font-family: var(--font-body, 'Poppins', system-ui, sans-serif);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--color-text-primary, #0f172a);
}

.gcc-logo-text strong { color: var(--color-primary, #0070f3); font-weight: 700; }

.gcc-cta-btn {
    padding: 10px 24px;
    border-radius: var(--radius-sm);
    background: var(--hi-navy, #0D1B2A);
    border: 1px solid var(--hi-navy, #0D1B2A);
    color: #FFFFFF;
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.gcc-cta-btn:hover {
    background: var(--hi-navy-mid, #1A2F4A);
    color: #FFFFFF;
    border-color: var(--hi-navy-mid, #1A2F4A);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.hi-header-cta {
    display: flex;
    align-items: center;
    gap: 16px;
}

.hi-auth-shell {
    display: flex;
    align-items: center;
    gap: 10px;
}


.hi-auth-shell .hi-auth-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(0, 112, 243, 0.3);
    border-radius: 8px;
    background: linear-gradient(135deg, #0070f3, #005bb5);
    color: #FFFFFF;
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-weight: 500;
    letter-spacing: 0.06em;
    font-size: 12px;
    padding: 10px 22px;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 4px 14px rgba(0, 112, 243, 0.15);
    line-height: 1;
    white-space: nowrap;
}

.hi-auth-shell .hi-auth-btn:hover {
    box-shadow: 0 6px 20px rgba(0, 112, 243, 0.25);
    transform: translateY(-1px);
}

.hi-auth-shell .hi-auth-outline {
    background: transparent;
    color: var(--color-text-secondary, #475569);
    border-color: rgba(15, 23, 42, 0.12);
    box-shadow: none;
}

.hi-auth-shell .hi-auth-outline:hover {
    background: rgba(255, 255, 255, 0.9);
    color: var(--color-primary, #0070f3);
    border-color: rgba(0, 112, 243, 0.3);
    transform: translateY(-1px);
}

.hi-auth-shell.hi-auth-logged {
    background: var(--btn-secondary-bg);
    border: 1px solid var(--color-border-secondary);
    border-radius: var(--radius-full);
    padding: 6px 16px;
    gap: 14px;
}

.hi-auth-user {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-primary);
}

.hi-auth-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-success);
    box-shadow: 0 0 10px var(--glow-green);
}

.hi-auth-link {
    color: var(--color-text-muted);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    transition: color 0.3s ease;
}

.hi-auth-link:hover {
    color: var(--color-primary);
}

/* ==================== ANIMATIONS & EFFECTS ==================== */

/* Aurora Text Effect - Clean Solid Color */
.gcc-text-aurora {
    color: var(--hi-blue, #2563EB);
    font-weight: inherit;
    letter-spacing: inherit;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Floating / Wobble Animation for Cards */
@keyframes floatWobble {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    25% { transform: translateY(-10px) rotate(1deg); }
    75% { transform: translateY(10px) rotate(-1deg); }
}

/* Shimmer Animation for Primary Buttons */
@keyframes shimmer {
    0% { transform: translateX(-150%) skewX(-15deg); }
    50% { transform: translateX(150%) skewX(-15deg); }
    100% { transform: translateX(150%) skewX(-15deg); }
}

.gcc-btn-hero, .gcc-btn-apply {
    position: relative;
    overflow: hidden;
}

.gcc-btn-hero::after, .gcc-btn-apply::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
    transform: translateX(-150%) skewX(-15deg);
    animation: shimmer 6s infinite ease-in-out;
    pointer-events: none;
}

/* Enhanced Card Hover Effects */
.gcc-feature-card, .gcc-impact-card, .gcc-stat-card {
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275), 
                box-shadow 0.4s ease, 
                border-color 0.4s ease,
                background 0.4s ease;
}

.gcc-feature-card:hover, .gcc-impact-card:hover, .gcc-stat-card:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: var(--shadow-glow-cyan);
    border-color: var(--color-border-hover);
    background: var(--card-bg-hover);
}

/* Trust Dot Pulse */
.gcc-trust-dot {
    position: relative;
}

.gcc-trust-dot::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: inherit;
    opacity: 0.7;
    animation: ping 2s cubic-bezier(0, 0, 0.2, 1) infinite;
}

@keyframes ping {
    75%, 100% {
        transform: translate(-50%, -50%) scale(2.5);
        opacity: 0;
    }
}

/* ==================== HERO SECTION ==================== */
.gcc-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 140px 20px 0;
    overflow: hidden;
    background: var(--hi-navy, #0D1B2A);
    color: #FFFFFF;
}

.gcc-hero-grid-pattern {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(37, 99, 235, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(37, 99, 235, 0.06) 1px, transparent 1px);
    background-size: 64px 64px;
    mask-image: radial-gradient(ellipse at 50% 30%, black 20%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at 50% 30%, black 20%, transparent 70%);
    pointer-events: none;
    z-index: 1;
}

.gcc-hero-stats-bar {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 24px 40px;
    margin-top: auto;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    position: relative;
    z-index: 10;
}

.gcc-hero-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 0 40px;
}

.gcc-hero-stat-value {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: #FFFFFF;
}

.gcc-hero-stat-label {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.45);
    text-transform: uppercase;
}

.gcc-hero-stat-divider {
    width: 1px;
    height: 32px;
    background: rgba(255, 255, 255, 0.1);
}

.gcc-hero-shell {
    width: 100%;
    max-width: 1400px;
    position: relative;
    z-index: 10;
}

.gcc-hero-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 60px;
    align-items: center;
}

.gcc-hero-copy {
    position: relative;
    z-index: 2;
}

.gcc-hero-pill {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    border-radius: var(--radius-full);
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    margin-bottom: 30px;
    animation: fadeInUp 1s ease forwards 0.2s;
    opacity: 0;
}

.gcc-hero-pill-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--hi-blue, #2563EB);
    box-shadow: 0 0 8px rgba(37, 99, 235, 0.6);
}

.gcc-title {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: clamp(3rem, 6vw, 5.5rem);
    font-weight: 800;
    line-height: 1.1;
    margin: 0 0 24px;
    color: #FFFFFF;
    letter-spacing: -0.04em;
    animation: fadeInUp 1s ease forwards 0.4s;
    opacity: 0;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.gcc-hero .gcc-text-aurora {
    color: var(--hi-blue-mid, #3B82F6);
}

/* Subtitle — hero-specific (white on navy) */
.gcc-hero .gcc-subtitle {
    font-size: clamp(1.125rem, 2vw, 1.25rem);
    font-weight: 400;
    color: rgba(255, 255, 255, 0.65);
    max-width: 600px;
    margin: 0 0 40px;
    line-height: 1.7;
    animation: fadeInUp 1s ease forwards 0.6s;
    opacity: 0;
}

/* Subtitle — outside hero (dark text on light bg) */
.gcc-subtitle {
    font-size: clamp(1.125rem, 2vw, 1.25rem);
    font-weight: 400;
    color: var(--hi-text-sec, #475569);
    max-width: 600px;
    margin: 0 0 40px;
    line-height: 1.7;
}

.gcc-hero-ctas {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    animation: fadeInUp 1s ease forwards 0.8s;
    opacity: 0;
}

.gcc-btn-hero {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 14px 28px;
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-size: 15px;
    font-weight: 600;
    color: #FFFFFF;
    text-decoration: none;
    border-radius: var(--radius-sm);
    background: var(--hi-blue, #2563EB);
    box-shadow: 0 4px 16px rgba(37, 99, 235, 0.3);
    transition: all 0.15s ease;
    border: none;
}

.gcc-btn-hero:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.4);
    background: var(--hi-blue-mid, #3B82F6);
}

/* Secondary button — default light-mode style */
.gcc-btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    border-radius: var(--radius-sm);
    text-decoration: none;
    color: var(--hi-navy, #0D1B2A);
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-weight: 600;
    font-size: 15px;
    background: transparent;
    border: 1px solid var(--hi-border, #E2E8F0);
    transition: all 0.15s ease;
}

.gcc-btn-secondary:hover {
    background: var(--hi-surface-2, #F1F5F9);
    border-color: var(--hi-border-strong, #CBD5E1);
    transform: translateY(-1px);
}

/* Secondary button — hero variant (white on navy) */
.gcc-hero .gcc-btn-secondary {
    color: #FFFFFF;
    border: 1px solid rgba(255, 255, 255, 0.25);
}

.gcc-hero .gcc-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.4);
}

.gcc-hero-trust {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 40px;
    animation: fadeIn 1s ease forwards 1s;
    opacity: 0;
}

/* Trust chips — hero variant (white on navy) */
.gcc-hero .gcc-trust-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: var(--radius-sm);
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.6);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

/* Trust chips — light mode default */
.gcc-trust-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: var(--radius-sm);
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    font-weight: 500;
    color: var(--hi-text-sec, #475569);
    background: var(--hi-surface, #F8FAFC);
    border: 1px solid var(--hi-border, #E2E8F0);
}

.gcc-trust-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.gcc-dot-cyan { background: var(--hi-blue, #2563EB); }
.gcc-dot-purple { background: var(--hi-blue-mid, #3B82F6); }
.gcc-dot-green { background: var(--hi-green, #059669); }

/* --- ORBIT ANIMATION SYSTEM --- */
.gcc-hero-visual {
    position: relative;
    height: 600px;
    display: flex;
    align-items: center;
    justify-content: center;
    perspective: 1000px;
}

/* Central glowing core */
.gcc-hero-core {
    position: absolute;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, var(--hi-blue, #2563EB), var(--hi-blue-mid, #3B82F6));
    filter: blur(40px);
    opacity: 0.35;
    animation: pulseCore 4s ease-in-out infinite;
    z-index: 0;
}

.gcc-hero-core::after {
    content: "";
    position: absolute;
    inset: 20px;
    background: #FFFFFF;
    border-radius: 50%;
    filter: blur(20px);
    opacity: 0.3;
}

/* Orbital Rings */
.gcc-hero-orbit {
    position: absolute;
    border-radius: 50%;
    border: 1px dashed rgba(37, 99, 235, 0.15);
    top: 50%;
    left: 50%;
    transform-style: preserve-3d;
}

.gcc-orbit-1 { 
    width: 440px; 
    height: 440px; 
    animation: rotateTrack 60s linear infinite; 
    transform: translate(-50%, -50%) rotateX(10deg) rotateY(10deg);
}

.gcc-orbit-2 { 
    width: 520px; 
    height: 520px; 
    animation: rotateTrack 80s linear infinite reverse; 
    opacity: 0.5; 
    transform: translate(-50%, -50%) rotateX(-15deg) rotateY(5deg);
}

/* Orbiting Cards */
.gcc-hero-card {
    position: absolute;
    width: 200px;
    padding: 20px;
    border-radius: var(--radius-lg);
    background: rgba(26, 47, 74, 0.7);
    backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    color: #FFFFFF;
    
    /* Center origin for orbit calculations */
    top: 50%;
    left: 50%;
    margin-top: -60px; 
    margin-left: -100px;
    
    /* Smooth floating feeling */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.gcc-hero-card:hover {
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
    border-color: rgba(37, 99, 235, 0.3);
    z-index: 100;
}

/* 
   Complex Orbits:
   We use prime number durations (23s, 29s, 37s) to prevent syncing.
   We combine the orbital rotation with a 'floatWobble' on the card itself.
*/

.gcc-card-1 {
    animation: orbit1 23s linear infinite; /* Prime number duration */
}

.gcc-card-2 {
    animation: orbit2 29s linear infinite; /* Prime number duration */
}

.gcc-card-3 {
    animation: orbit3 37s linear infinite; /* Prime number duration */
}

@keyframes rotateTrack {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes pulseCore {
    0%, 100% { transform: scale(1); opacity: 0.35; }
    50% { transform: scale(1.05); opacity: 0.5; }
}

/* 
   Updated Orbit Logic: 
   Rotate(angle) -> Translate(Radius) -> Rotate(-angle) 
   + Added vertical Sine wave bobbing for randomness
*/

@keyframes orbit1 {
    0% { transform: rotate(0deg) translate(220px) rotate(0deg) translateY(0); }
    25% { transform: rotate(90deg) translate(220px) rotate(-90deg) translateY(-10px); }
    50% { transform: rotate(180deg) translate(220px) rotate(-180deg) translateY(0); }
    75% { transform: rotate(270deg) translate(220px) rotate(-270deg) translateY(10px); }
    100% { transform: rotate(360deg) translate(220px) rotate(-360deg) translateY(0); }
}

@keyframes orbit2 {
    0% { transform: rotate(120deg) translate(280px) rotate(-120deg) translateY(0); }
    50% { transform: rotate(300deg) translate(280px) rotate(-300deg) translateY(-15px); }
    100% { transform: rotate(480deg) translate(280px) rotate(-480deg) translateY(0); }
}

@keyframes orbit3 {
    0% { transform: rotate(240deg) translate(250px) rotate(-240deg) translateY(0); }
    50% { transform: rotate(420deg) translate(250px) rotate(-420deg) translateY(12px); }
    100% { transform: rotate(600deg) translate(250px) rotate(-600deg) translateY(0); }
}

.gcc-hero-card-title {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: 8px;
    font-weight: 500;
}

.gcc-hero-card-value {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: 15px;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 4px;
}

.gcc-hero-card-sub {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.4);
}


/* ==================== SPOTLIGHT EFFECT ==================== */
.gcc-stat-card, .gcc-impact-card, .gcc-feature-card {
    position: relative;
    overflow: hidden;
}

.gcc-stat-card::before, .gcc-impact-card::before, .gcc-feature-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(
        600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
        rgba(255, 255, 255, 0.06),
        transparent 40%
    );
    z-index: 0;
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
}

.gcc-stat-card:hover::before, .gcc-impact-card:hover::before, .gcc-feature-card:hover::before {
    opacity: 1;
}

/* Ensure content stays above spotlight */
.gcc-stat-number, .gcc-stat-label, 
.gcc-impact-icon, .gcc-impact-value, .gcc-impact-label, .gcc-impact-progress,
.gcc-feature-icon, .gcc-feature-title, .gcc-feature-desc, .gcc-feature-text {
    position: relative;
    z-index: 1;
}

/* ==================== VISION & GROWTH ==================== */
.gcc-vision, .gcc-growth {
    padding: 120px 20px;
}

.gcc-vision .gcc-container,
.gcc-growth .gcc-container {
    max-width: 1200px;
    margin: 0 auto;
}

.gcc-vision-header, .gcc-growth-header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 80px;
}

.gcc-section-title {
    font-size: clamp(2rem, 4vw, 3rem);
    margin-bottom: 24px;
}

.gcc-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 60px;
}

.gcc-stat-card {
    padding: 40px 30px;
    border-radius: var(--radius-xl);
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    text-align: center;
    transition: all 0.3s ease;
}

.gcc-stat-card:hover {
    background: var(--card-bg-hover);
    transform: translateY(-5px);
}

.gcc-stat-number {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--hi-navy, #0D1B2A);
    margin-bottom: 10px;
}

.gcc-stat-label {
    color: var(--hi-text-sec, #475569);
    font-size: 14px;
}

.gcc-impact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
}

.gcc-impact-card {
    padding: 40px;
    border-radius: var(--radius-xl);
    background: var(--card-gradient);
    border: 1px solid var(--card-border);
    transition: all 0.3s ease;
}

.gcc-impact-card:hover {
    border-color: var(--card-border-hover);
    transform: translateY(-5px);
}

.gcc-impact-icon {
    width: 60px;
    height: 60px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
    background: var(--btn-secondary-bg);
    color: var(--color-text-primary);
}
.gcc-icon-cyan { color: var(--hi-blue, #2563EB); }
.gcc-icon-purple { color: var(--hi-navy-mid, #1A2F4A); }
.gcc-icon-green { color: var(--hi-green, #059669); }


.gcc-impact-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 8px;
}

.gcc-impact-label {
    font-size: 14px;
    color: var(--color-text-secondary, #475569);
}

.gcc-hira-process {
    max-width: 1200px;
    margin: 0 auto;
}

.gcc-hira-process-header {
    text-align: center;
    max-width: 900px;
    margin: 0 auto 38px;
}

.gcc-hira-process-title {
    margin: 0 0 12px;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--color-text-primary);
}

.gcc-hira-process-subtitle {
    margin: 0;
    color: var(--color-text-secondary, #475569);
    line-height: 1.7;
}

.gcc-hira-flow {
    position: relative;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 32px;
    overflow: hidden;
    padding: 40px 20px;
    border-radius: 28px;
    margin-top: 40px;
}

.gcc-hira-flow::before {
    content: "";
    position: absolute;
    inset: -14px;
    border-radius: 28px;
    background: radial-gradient(800px circle at 15% 20%, rgba(56, 189, 248, 0.10), transparent 45%),
                radial-gradient(900px circle at 85% 70%, rgba(168, 85, 247, 0.10), transparent 45%),
                linear-gradient(135deg, rgba(52, 211, 153, 0.05), rgba(56, 189, 248, 0.02));
    opacity: 0.9;
    pointer-events: none;
    filter: blur(0px);
}

.gcc-hira-flow::after {
    content: "";
    position: absolute;
    top: -10px;
    left: -20%;
    width: 40%;
    height: calc(100% + 20px);
    background: linear-gradient(90deg, transparent, rgba(56, 189, 248, 0.10), transparent);
    pointer-events: none;
    animation: hiraScan 7.5s ease-in-out infinite;
    mix-blend-mode: screen;
}

.gcc-hira-step {
    position: relative;
    padding: 32px 24px 24px 24px;
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    transition: var(--theme-transition);
}

.gcc-hira-step::before {
    content: attr(data-step);
    position: absolute;
    top: -16px;
    left: 24px;
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    letter-spacing: 0.06em;
    font-size: 14px;
    color: var(--btn-primary-text);
    background: var(--btn-primary-bg);
    border: 2px solid var(--color-bg-primary);
    box-shadow: var(--shadow-lg);
}

.gcc-hira-step-top {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 12px;
}

.gcc-hira-step-name {
    font-size: 18px;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--color-text-primary);
    margin-bottom: 8px;
}

.gcc-hira-step-desc {
    margin: 0;
    color: var(--color-text-secondary);
    line-height: 1.7;
    font-size: 15px;
}

.gcc-hira-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 24px;
    padding: 0 10px;
    border-radius: var(--radius-full);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 800;
    border: 1px solid var(--color-border-primary);
    background: var(--btn-secondary-bg);
    color: var(--color-text-primary);
}

.gcc-hira-tag-ai {
    background: var(--glow-cyan);
    border-color: var(--color-accent-cyan);
    color: var(--color-accent-cyan);
    font-weight: 700;
}

.gcc-hira-tag-human {
    background: var(--glow-purple);
    border-color: var(--color-accent-purple);
    color: var(--color-accent-purple);
    font-weight: 700;
}

.gcc-hira-step:hover {
    border-color: var(--color-border-hover);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

@keyframes hiraScan {
    0% { transform: translateX(0); opacity: 0; }
    12% { opacity: 0.55; }
    50% { opacity: 0.25; }
    88% { opacity: 0.55; }
    100% { transform: translateX(350%); opacity: 0; }
}

/* ==================== ENGINE (3D) ==================== */
.gcc-engine {
    padding: 120px 20px;
    background: var(--color-bg-primary);
}

.gcc-engine-layout {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.gcc-engine-visual {
    position: relative;
    height: 500px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

#gcc-3d-canvas {
    width: 100%;
    height: 100%;
    position: relative;
}

.gcc-engine-content {
    padding-right: 40px;
}

.gcc-engine-title {
    font-size: 3rem;
    margin-bottom: 24px;
}

.gcc-engine-desc {
    font-size: 1.125rem;
    color: var(--color-text-secondary, #475569);
    margin-bottom: 40px;
}

.gcc-features {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.gcc-feature-card {
    display: flex;
    gap: 20px;
    padding: 24px;
    border-radius: var(--radius-lg);
    background: var(--card-bg);
    border: 1px solid var(--card-border);
}

.gcc-feature-icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    border-radius: var(--radius-md);
    background: var(--btn-secondary-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-primary);
}

.gcc-feature-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 8px;
}

.gcc-feature-desc {
    font-size: 14px;
    color: var(--color-text-secondary, #475569);
    line-height: 1.5;
}

/* ==================== APPLY ==================== */
.gcc-apply {
    padding: 160px 20px;
    text-align: center;
}

.gcc-apply-content {
    max-width: 900px;
    margin: 0 auto;
    padding: 80px 40px;
    border-radius: var(--radius-xl);
    background: var(--hi-surface, #F8FAFC);
    border: 1px solid var(--hi-border, #E2E8F0);
}

.gcc-apply-label {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 12px;
    font-weight: 500;
    color: var(--hi-blue, #2563EB);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 24px;
}

.gcc-apply-title {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    margin-bottom: 30px;
    color: var(--hi-navy, #0D1B2A);
}

.gcc-apply-desc {
    font-size: 1.25rem;
    color: var(--color-text-secondary, #475569);
    margin-bottom: 50px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.gcc-btn-apply {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 16px 32px;
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-size: 16px;
    font-weight: 600;
    color: #FFFFFF;
    background: var(--hi-blue, #2563EB);
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: all 0.15s ease;
    border: none;
    box-shadow: var(--btn-primary-shadow);
}

.gcc-btn-apply:hover {
    transform: translateY(-1px);
    background: var(--hi-blue-mid, #3B82F6);
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.3);
}

.gcc-gradient-text {
    background: linear-gradient(45deg, var(--color-accent-cyan), var(--color-accent-purple));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ==================== FOOTER (Elegant Light v2.1) ==================== */
.gcc-footer {
    padding: 56px 48px 28px;
    border-top: 1px solid rgba(15, 23, 42, 0.06);
    background: #f8fafc;
    color: var(--color-text-secondary, #475569);
    font-family: var(--font-body);
}
.gcc-footer-container {
    max-width: 1280px;
    margin: 0 auto 36px;
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 48px;
    align-items: flex-start;
    text-align: left;
}
.gcc-footer-brand { max-width: 300px; }
.gcc-footer-logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: #0f172a;
    margin-bottom: 14px;
}
.gcc-footer-logo-mark {
    width: 36px; height: 36px;
    background: linear-gradient(135deg, #0070f3, #005bb5);
    border-radius: 8px;
    display: grid;
    place-items: center;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 600;
    color: #fff;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}
.gcc-footer-logo-text {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: #0f172a;
}
.gcc-footer-logo-text span { color: #0070f3; }
.gcc-footer-col {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.gcc-footer-col h4 {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: #64748b;
    margin: 0 0 6px;
}
.gcc-footer-col a {
    font-family: var(--font-mono);
    font-size: 12px;
    color: #475569;
    font-weight: 500;
    text-decoration: none;
    transition: color 0.2s;
}
.gcc-footer-col a:hover { color: #0f172a; }
.gcc-footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 24px;
    border-top: 1px solid rgba(15, 23, 42, 0.06);
    font-family: var(--font-mono);
    font-size: 11px;
    color: #64748b;
    letter-spacing: 0.04em;
    max-width: 1280px;
    margin: 0 auto;
    gap: 16px;
    flex-wrap: wrap;
}
.gcc-footer-bottom .gcc-footer-copyright,
.gcc-footer-bottom .gcc-footer-mono { margin: 0; color: #64748b; }

@media (max-width: 1100px) {
    .gcc-footer-container { grid-template-columns: 1fr 1fr; gap: 36px; }
}
@media (max-width: 640px) {
    .gcc-footer { padding: 40px 24px 20px; }
    .gcc-footer-container { grid-template-columns: 1fr; gap: 28px; }
    .gcc-footer-bottom { flex-direction: column; text-align: center; gap: 8px; }
}

/* Legacy .gcc-footer-links (old single-row footer layout) — hidden since we now use .gcc-footer-col grid */
.gcc-footer-links { display: none; }

/* ==================== RESPONSIVE ==================== */
@media (max-width: 1024px) {
    .gcc-hero-grid { grid-template-columns: 1fr; text-align: center; gap: 80px; }
    .gcc-hero-copy { display: flex; flex-direction: column; align-items: center; }
    .gcc-hero-ctas { justify-content: center; }
    .gcc-subtitle { margin-left: auto; margin-right: auto; }
    .gcc-hero-visual { height: 500px; }
    .gcc-hero-stats-bar { padding: 20px 20px; gap: 0; }
    .gcc-hero-stat { padding: 0 24px; }
    .gcc-stats-grid { grid-template-columns: 1fr; }
    .gcc-engine-layout { grid-template-columns: 1fr; }
    .gcc-engine-content { padding-right: 0; }
}

@media (max-width: 768px) {
    .gcc-header { padding: 15px 20px; }
    .gcc-logo-text { font-size: 18px; }
    .gcc-cta-btn { display: none; }
    .gcc-hero { padding-top: 120px; }
    .gcc-nav { display: none; }
    .gcc-btn-hero, .gcc-btn-secondary { width: 100%; justify-content: center; }
    .gcc-hero-stats-bar { flex-wrap: wrap; gap: 16px; padding: 20px; }
    .gcc-hero-stat { padding: 8px 16px; }
    .gcc-hero-stat-divider { display: none; }
    
    /* Simplified animations for mobile */
    .gcc-hero-card { display: none; }
}

/* ==================== PLATFORM PAGES (OPPORTUNITY / EDU / DASHBOARDS) ==================== */
/* Header is now sticky (in-flow), so these shells no longer need a 160px
   top-padding to compensate for an overlapping fixed header. */
.hi-page-shell {
    min-height: 100vh;
    padding: 48px 20px 140px;
    background: var(--hi-surface, #F8FAFC);
    display: flex;
    flex-direction: column;
}

.hi-page-contained {
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 40px;
    flex: 1;
}

.hi-page-hero {
    text-align: center;
    margin-bottom: 20px;
}

.hi-page-hero h1 {
    font-size: clamp(2.5rem, 4vw, 3.8rem);
    color: var(--hi-text-primary);
    margin-bottom: 16px;
}

.hi-page-hero p {
    color: var(--hi-text-muted);
    max-width: 720px;
    margin: 0 auto;
    line-height: 1.8;
}

.hi-pill {
    display: inline-flex;
    align-items: center;
    padding: 6px 16px;
    border-radius: var(--radius-full);
    background: var(--glow-cyan);
    border: 1px solid var(--color-accent-cyan);
    color: var(--color-accent-cyan);
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    margin-bottom: 20px;
}


.hi-section {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-xl);
    padding: 40px;
    margin-bottom: 0;
    box-shadow: var(--shadow-md);
}

.hi-filter-panel {
    margin-bottom: 30px;
}

.hi-filter-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.hi-filter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

.hi-filter-item label {
    display: block;
    font-size: 13px;
    color: var(--hi-text-muted);
    margin-bottom: 8px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.hi-filter-item input,
.hi-filter-item select {
    width: 100%;
    padding: 12px 14px;
    border-radius: var(--radius-md);
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-text);
}

.hi-filter-submit {
    width: fit-content;
}

.hi-filter-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: center;
}

.hi-filter-reset {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
}

.hi-opportunity-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.hi-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 14px;
    border-radius: 999px;
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border: 1px solid var(--hi-border, #E2E8F0);
    background: var(--hi-surface-2, #F1F5F9);
    color: var(--hi-text-sec, #475569);
}

.hi-status-live {
    background: var(--hi-green-light, #D1FAE5);
    border-color: rgba(5, 150, 105, 0.3);
    color: var(--hi-green, #059669);
}


.hi-status-draft {
    background: rgba(217, 119, 6, 0.12);
    border-color: var(--color-warning);
    color: var(--color-warning);
}


.hi-opportunity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
}

.hi-opportunity-card {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-xl);
    padding: 26px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    box-shadow: var(--card-shadow);
    transition: var(--theme-transition);
}

.hi-card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.hi-card-title {
    font-size: 1.3rem;
    margin: 0;
    color: var(--color-text-primary);
}

.hi-card-company {
    color: var(--hi-text-muted);
    margin: 0;
}

.hi-card-details {
    list-style: none;
    padding: 0;
    margin: 0;
    color: var(--hi-text-muted);
    display: grid;
    gap: 8px;
    font-size: 14px;
}

.hi-card-tax {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.hi-tag {
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.25);
    font-size: 12px;
    color: var(--hi-text-muted);
}

.hi-card-link {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 600;
}

.hi-empty-state {
    text-align: center;
    padding: 40px;
    border: 1px dashed rgba(148, 163, 184, 0.2);
    border-radius: 24px;
    color: var(--hi-text-muted);
}

.hi-profile-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 16px;
}

.hi-profile-layout,
.hi-studio-layout {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 24px;
}

.hi-profile-column,
.hi-studio-card {
    padding: 20px;
    border-radius: 20px;
    border: 1px solid var(--card-border);
    background: var(--card-bg);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.hi-column-label {
    font-size: 12px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(148, 163, 184, 0.8);
}

.hi-field-stack {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.hi-field-stack label {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 13px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(148, 163, 184, 0.85);
}

.hi-field-stack input,
.hi-field-stack select,
.hi-field-stack textarea {
    width: 100%;
    padding: 12px 14px;
    border-radius: var(--radius-md);
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-text);
    font-size: 15px;
    transition: border 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.hi-field-stack input:focus,
.hi-field-stack select:focus,
.hi-field-stack textarea:focus {
    border-color: rgba(56, 189, 248, 0.5);
    box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.12);
    outline: none;
}

.hi-profile-textarea textarea {
    min-height: 140px;
    resize: vertical;
}

.hi-profile-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 16px;
}

.hi-edu-card {
    background: var(--hi-card);
    border: 1px solid rgba(148, 163, 184, 0.15);
    border-radius: 24px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hi-form.hi-profile-textarea {
    min-height: 140px;
    resize: vertical;
}

.hi-workspace-suite {
    margin-top: var(--card-spacing);
    display: flex;
    flex-direction: column;
    gap: var(--card-spacing);
}

.hi-workspace-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 10px;
    border-radius: 999px;
    border: 1px solid var(--card-border);
    background: var(--card-bg);
    box-shadow: var(--shadow-sm);
}

.hi-tab-button {
    border: none;
    border-radius: 999px;
    padding: 10px 20px;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all 0.25s ease;
}

.hi-tab-button:hover {
    background: var(--btn-secondary-bg-hover);
    color: var(--color-text-primary);
}

.hi-tab-button:focus-visible {
    outline: 2px solid var(--color-border-focus);
    outline-offset: 3px;
}

.hi-tab-button.active {
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    box-shadow: var(--shadow-md);
}

.hi-workspace-panels {
    position: relative;
}

.hi-tab-panel {
    display: none;
    animation: hiPanelFade 0.35s ease;
}

.hi-tab-panel.active {
    display: block;
}

@keyframes hiPanelFade {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.hi-job-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 120px auto;
    align-items: center;
    gap: 16px;
    padding: 18px 0;
    border-bottom: 1px solid var(--color-border-primary);
}

.hi-job-row:last-child {
    border-bottom: none;
}

.hi-job-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 80px;
    padding: 6px 16px;
    border-radius: var(--radius-full);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: 1px solid var(--color-border-primary);
    background: var(--btn-secondary-bg);
    color: var(--color-text-secondary);
}

.hi-job-status--live {
    border-color: var(--color-success);
    background: var(--glow-green);
    color: var(--color-success);
}

.hi-job-status--draft {
    border-color: var(--color-warning);
    background: rgba(217, 119, 6, 0.12);
    color: var(--color-warning);
}

.hi-job-status--pending {
    border-color: var(--color-info);
    background: rgba(37, 99, 235, 0.12);
    color: var(--color-info);
}

.hi-job-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-end;
}

/* Plain Text JD Toggle */
.hi-job-input-toggle {
    display: flex;
    gap: 12px;
    padding: 8px;
    border-radius: 999px;
    border: 1px solid var(--card-border);
    background: var(--card-bg);
    box-shadow: var(--shadow-sm);
    margin-bottom: 24px;
    width: fit-content;
}

.hi-toggle-btn {
    border: none;
    border-radius: 999px;
    padding: 10px 24px;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all 0.25s ease;
    font-weight: 500;
}

.hi-toggle-btn:hover {
    background: var(--btn-secondary-bg-hover);
    color: var(--color-text-primary);
}

.hi-toggle-btn:focus-visible {
    outline: 2px solid var(--color-border-focus);
    outline-offset: 3px;
}

.hi-toggle-btn.active {
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    box-shadow: var(--shadow-md);
}

/* Plain Text JD Section */
.hi-plaintext-jd-section {
    margin-bottom: 24px;
}

.hi-plaintext-jd-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hi-plaintext-jd-label {
    display: flex;
    flex-direction: column;
    gap: 10px;
    font-size: 13px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.hi-plaintext-jd-label textarea {
    width: 100%;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-text);
    font-size: 15px;
    line-height: 1.6;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    transition: border 0.25s ease, box-shadow 0.25s ease;
    resize: vertical;
    min-height: 280px;
}

.hi-plaintext-jd-label textarea:focus {
    border-color: var(--input-border-focus);
    background: var(--input-bg-focus);
    box-shadow: 0 0 0 3px var(--glow-cyan);
    outline: none;
}

.hi-plaintext-jd-label textarea::placeholder {
    color: var(--input-placeholder);
}

.hi-plaintext-jd-hint {
    font-size: 12px;
    color: var(--color-text-muted);
    font-style: italic;
    margin-top: -4px;
    letter-spacing: 0.02em;
}

/* JD Search Toggle */
.hi-jd-input-toggle {
    display: flex;
    gap: 12px;
    padding: 8px;
    border-radius: 999px;
    border: 1px solid var(--card-border);
    background: var(--card-bg);
    box-shadow: var(--shadow-sm);
    margin-bottom: 24px;
    width: fit-content;
}

.hi-jd-toggle-btn {
    border: none;
    border-radius: 999px;
    padding: 10px 24px;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all 0.25s ease;
    font-weight: 500;
}

.hi-jd-toggle-btn:hover {
    background: var(--btn-secondary-bg-hover);
    color: var(--color-text-primary);
}

.hi-jd-toggle-btn:focus-visible {
    outline: 2px solid var(--color-border-focus);
    outline-offset: 3px;
}

.hi-jd-toggle-btn.active {
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    box-shadow: var(--shadow-md);
}

/* JD Text Input Section */
.hi-jd-text-section {
    margin-bottom: 24px;
}

.hi-jd-text-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hi-jd-text-label {
    display: flex;
    flex-direction: column;
    gap: 10px;
    font-size: 13px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.hi-jd-text-label textarea {
    width: 100%;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-text);
    font-size: 15px;
    line-height: 1.6;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    transition: border 0.25s ease, box-shadow 0.25s ease;
    resize: vertical;
    min-height: 320px;
}

.hi-jd-text-label textarea:focus {
    border-color: var(--input-border-focus);
    background: var(--input-bg-focus);
    box-shadow: 0 0 0 3px var(--glow-cyan);
    outline: none;
}

.hi-jd-text-label textarea::placeholder {
    color: var(--input-placeholder);
}

.hi-jd-text-hint {
    font-size: 12px;
    color: var(--color-text-muted);
    font-style: italic;
    margin-top: -4px;
    letter-spacing: 0.02em;
}

.hi-job-actions .hi-profile-link {
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 8px 18px;
    border-radius: 999px;
    border: 1px solid var(--hi-border, #E2E8F0);
    background: #FFFFFF;
    transition: all 0.15s ease;
}

.hi-job-actions .hi-profile-link:hover {
    border-color: var(--hi-blue, #2563EB);
    color: var(--hi-blue, #2563EB);
    background: var(--hi-blue-pale, #EFF6FF);
}

.hi-edit-job-btn {
    border: none;
    background: var(--hi-blue-pale, #EFF6FF);
    border-radius: var(--radius-sm);
    padding: 8px 18px;
    color: var(--hi-blue, #2563EB);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.15s ease;
}

.hi-edit-job-btn:hover {
    transform: translateY(-1px);
    background: var(--hi-blue, #2563EB);
    color: #FFFFFF;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}

.hi-edit-job-btn:focus-visible {
    outline: 2px solid rgba(37, 99, 235, 0.4);
    outline-offset: 3px;
}

.hi-search-benefits {
    list-style: none;
    padding: 0;
    margin: 20px 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    color: rgba(226, 232, 240, 0.8);
}

.hi-page-opportunity {
    min-height: 100vh;
    background: var(--hi-surface, #F8FAFC);
}

.hi-single-opportunity-shell {
    padding: 140px 20px 100px;
}

.hi-opportunity-hero {
    text-align: center;
    margin-bottom: 60px;
}

.hi-opportunity-meta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-bottom: 20px;
}

.hi-opportunity-company {
    font-size: 18px;
    color: #475569; /* slate-600 — readable on light bg */
    margin: 12px 0 24px;
}

.hi-opportunity-highlights {
    list-style: none;
    padding: 0;
    margin: 24px 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px;
    color: #475569;
}

.hi-opportunity-highlights li {
    font-size: 14px;
}

.hi-opportunity-highlights strong {
    color: #0f172a;
}

.hi-hero-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
    margin-top: 32px;
}

.hi-opportunity-detail {
    margin-top: 40px;
}

.hi-two-column {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 40px;
    align-items: start;
}

.hi-opportunity-content {
    color: #334155; /* slate-700 — strong readable body text on light bg */
    line-height: 1.75;
    font-size: 15.5px;
}

.hi-opportunity-summary {
    font-size: 18px;
    color: #1e293b; /* slate-800 — slightly darker for the lead paragraph */
    margin-bottom: 32px;
    line-height: 1.65;
    font-weight: 500;
}

.hi-opportunity-description {
    font-size: 15.5px;
    color: #334155;
}

.hi-opportunity-description p,
.hi-opportunity-description li {
    color: #334155;
}

.hi-opportunity-description strong,
.hi-opportunity-description b {
    color: #0f172a;
    font-weight: 600;
}

/* Responsibilities / Required Qualifications / Preferred Qualifications sections */
.hi-opportunity-section {
    margin-top: 40px;
    padding-top: 32px;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
}
.hi-opportunity-section:first-of-type { border-top: 0; padding-top: 0; margin-top: 32px; }

.hi-opportunity-section h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: #0f172a;
    margin: 0 0 16px;
}

.hi-opportunity-section-content,
.hi-opportunity-section-content p,
.hi-opportunity-section-content li {
    color: #334155;
    line-height: 1.75;
    font-size: 15.5px;
}
.hi-opportunity-section-content ul,
.hi-opportunity-section-content ol {
    margin: 12px 0 16px;
    padding-left: 22px;
}
.hi-opportunity-section-content li { margin-bottom: 8px; }
.hi-opportunity-section-content strong { color: #0f172a; font-weight: 600; }

.hi-opportunity-description h2,
.hi-opportunity-description h3 {
    color: var(--color-text-primary);
    margin-top: 32px;
    margin-bottom: 16px;
}

.hi-opportunity-description ul,
.hi-opportunity-description ol {
    margin: 16px 0;
    padding-left: 24px;
}

.hi-opportunity-description li {
    margin-bottom: 8px;
}

.hi-opportunity-original-link {
    margin-top: 32px;
    padding: 20px 24px;
    border-radius: 12px;
    background: rgba(245, 158, 11, 0.06);
    border: 1px solid rgba(245, 158, 11, 0.2);
}
.hi-opportunity-original-link h3 {
    color: #f59e0b;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 8px;
}
.hi-opportunity-original-link p {
    margin: 0;
    line-height: 1.6;
}
a.hi-original-link {
    color: #f59e0b;
    font-weight: 600;
    text-decoration: none;
    border-bottom: 1px solid rgba(245, 158, 11, 0.3);
    transition: border-color 0.2s;
}
a.hi-original-link:hover {
    border-bottom-color: #f59e0b;
}

.hi-opportunity-sidebar {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: sticky;
    top: 120px;
}

.hi-card {
    padding: 24px;
    border-radius: 20px;
    border: 1px solid var(--card-border);
    background: var(--card-bg);
    box-shadow: var(--card-shadow);
}

.hi-card-glass {
    backdrop-filter: blur(12px);
}

.hi-card h3 {
    margin: 0 0 16px;
    font-family: 'Inter', 'Poppins', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #64748b; /* slate-500 — clear micro-label on light bg */
}

.hi-sidebar-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hi-sidebar-list li {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.1);
}

.hi-sidebar-list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.hi-sidebar-list span {
    font-family: 'Inter', 'Poppins', sans-serif;
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b; /* slate-500 */
}

.hi-sidebar-list strong {
    color: #0f172a; /* slate-900 — strong primary for the value */
    font-size: 14px;
    font-weight: 600;
}

.hi-sidebar-list a {
    color: var(--color-primary);
    text-decoration: none;
    font-size: 14px;
    transition: color 0.2s ease;
}

.hi-sidebar-list a:hover {
    color: var(--color-primary-hover);
}

.hi-sidebar-cta {
    width: 100%;
    margin-top: 16px;
    text-align: center;
}

.hi-sidebar-note {
    margin-top: 16px;
    font-size: 13px;
    line-height: 1.6;
    color: #64748b; /* slate-500 — visible on light card */
    line-height: 1.6;
}

.hi-card-tags h3 {
    margin-bottom: 12px;
}

.hi-tag-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

@media (max-width: 1024px) {
    .hi-two-column {
        grid-template-columns: 1fr;
    }

    .hi-opportunity-sidebar {
        position: static;
    }
}

.hi-owner-controls {
    margin-top: 30px;
    padding: 20px;
    border: 1px solid var(--hi-border, #E2E8F0);
    border-radius: var(--radius-xl);
    background: #FFFFFF;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.hi-owner-controls h4 {
    margin: 0;
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 12px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-owner-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.hi-owner-actions form {
    margin: 0;
}

.hi-owner-actions button {
    border: 1px solid var(--color-border-secondary);
    background: var(--card-bg);
    color: var(--color-text-primary);
    padding: 10px 18px;
    border-radius: 12px;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.2s ease;
}

.hi-owner-actions button:hover {
    border-color: var(--color-border-hover);
    color: var(--color-primary);
    transform: translateY(-1px);
}

.hi-owner-actions .hi-danger {
    border-color: rgba(248, 113, 113, 0.3);
    color: #f87171;
}

.hi-owner-actions .hi-danger:hover {
    border-color: rgba(248, 113, 113, 0.6);
    color: #fecaca;
}

.hi-dashboard-table {
    width: 100%;
    border-collapse: collapse;
}

.hi-dashboard-table th,
.hi-dashboard-table td {
    padding: 14px 12px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.15);
    text-align: left;
    color: var(--hi-text-muted);
}

.hi-dashboard-table th {
    color: var(--hi-text-primary);
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0.1em;
}

@media (max-width: 1024px) {
    .hi-edu-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .hi-profile-avatar-field {
        flex-direction: column;
        align-items: flex-start;
    }

    .hi-profile-layout,
    .hi-studio-layout {
        grid-template-columns: 1fr;
    }

    .hi-workspace-tabs {
        border-radius: 24px;
        flex-direction: column;
        gap: 8px;
    }

    .hi-tab-button {
        width: 100%;
        text-align: center;
    }

    .hi-job-row {
        grid-template-columns: 1fr;
    }

    .hi-job-actions {
        width: 100%;
        justify-content: space-between;
    }
}

/* ==================== MODAL ==================== */
.gcc-modal {
    display: none;
    position: fixed;
    z-index: 2000;
    inset: 0;
    background: var(--modal-overlay, rgba(13, 27, 42, 0.6));
    backdrop-filter: blur(10px);
    padding: 60px 20px;
    overflow-y: auto;
}

.gcc-modal,
.gcc-modal-content {
    -ms-overflow-style: none; /* IE/Edge */
    scrollbar-width: none; /* Firefox */
}

.gcc-modal::-webkit-scrollbar,
.gcc-modal-content::-webkit-scrollbar {
    display: none; /* Chrome/Safari */
}

.gcc-modal.show { display: block; }

.gcc-modal-content {
    position: relative;
    background: #FFFFFF;
    margin: 0 auto;
    padding: 44px 44px 40px;
    width: 100%;
    max-width: 640px;
    max-height: calc(100vh - 120px);
    overflow: auto;
    border-radius: var(--radius-xl);
    border: 1px solid var(--hi-border, #E2E8F0);
    box-shadow: var(--shadow-2xl);
}

.gcc-close-modal {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: var(--hi-text-sec, #475569);
    background: var(--hi-surface, #F8FAFC);
    border: 1px solid var(--hi-border, #E2E8F0);
    border-radius: 999px;
    transition: transform 0.15s ease, color 0.15s ease, background 0.15s ease;
}

.gcc-close-modal:hover {
    color: var(--color-text-primary);
    background: var(--card-bg-hover);
    border-color: var(--color-border-hover);
    transform: translateY(-1px);
}

.gcc-modal-header {
    padding-right: 52px;
    margin-bottom: 18px;
}

.gcc-modal-heading {
    font-size: 28px;
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 10px;
    color: var(--color-text-primary);
}

.gcc-modal-subtitle {
    margin: 0;
    color: rgba(148, 163, 184, 0.95);
    font-size: 16px;
    line-height: 1.6;
}

.gcc-modal-value-prop {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, auto));
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin: 20px 0 18px;
    padding: 18px 32px;
    border-radius: var(--radius-lg);
    background: var(--hi-blue-pale, #EFF6FF);
    border: 1px solid var(--hi-blue-light, #DBEAFE);
}

.gcc-value-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 4px;
}

.gcc-value-label {
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(148, 163, 184, 0.85);
}

.gcc-value-amount {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-text-primary);
}

.gcc-value-amount.success {
    color: #34d399;
}

.gcc-value-divider {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(56, 189, 248, 0.08);
    border: 1px solid rgba(56, 189, 248, 0.18);
    color: rgba(56, 189, 248, 0.95);
    font-weight: 700;
}

.gcc-modal-desc {
    margin: 0 0 22px;
    color: rgba(203, 213, 225, 0.9);
    line-height: 1.7;
}

/* ==================== UNIFIED AUTH MODAL v2 ==================== */

/* Overlay */
.hi-auth-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 2100;
    background: rgba(15, 23, 42, 0.40);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    overflow-y: auto;
    padding: 40px 16px;
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.hi-auth-overlay::-webkit-scrollbar { display: none; }
.hi-auth-overlay.show { display: flex; align-items: flex-start; justify-content: center; }

/* Panel */
.hi-auth-panel {
    position: relative;
    width: 100%;
    max-width: 680px;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    border: 1px solid #e2e8f0;
    margin: auto;
    animation: hiAuthIn 0.2s ease-out;
}
@keyframes hiAuthIn {
    from { opacity: 0; transform: scale(0.96) translateY(8px); }
    to   { opacity: 1; transform: scale(1)    translateY(0); }
}

/* Close */
.hi-auth-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: #f8fafc;
    border-radius: 50%;
    color: #94a3b8;
    cursor: pointer;
    transition: all 0.15s ease;
    z-index: 5;
}
.hi-auth-close:hover { color: #0f172a; background: #f1f5f9; }

/* Body */
.hi-auth-body {
    padding: 40px 40px 0;
    max-height: calc(100vh - 160px);
    overflow-y: auto;
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.hi-auth-body::-webkit-scrollbar { display: none; }

/* Header */
.hi-auth-header { margin-bottom: 32px; }
.hi-auth-sup {
    font-size: 11px;
    font-weight: 700;
    color: #2563eb;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    margin: 0 0 8px;
    line-height: 1;
}
.hi-auth-title {
    font-family: 'Poppins', 'Inter', system-ui, sans-serif;
    font-size: clamp(24px, 4vw, 32px);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin: 0 0 10px;
    color: #0f172a !important;
    background: none !important;
    -webkit-text-fill-color: #0f172a !important;
}
.hi-auth-sub {
    font-size: 14px;
    line-height: 1.6;
    color: #64748b;
    margin: 0;
}

/* Segmented Control */
.hi-auth-segments {
    display: flex;
    padding: 4px;
    background: rgba(241, 245, 249, 0.8);
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    margin-bottom: 28px;
    gap: 0;
}
.hi-auth-seg {
    flex: 1;
    padding: 10px 6px;
    font-size: 12px;
    font-weight: 600;
    text-align: center;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: #64748b;
    cursor: pointer;
    transition: all 0.2s ease;
    line-height: 1.2;
    white-space: normal;
}

/* Hide global chrome on admin dashboard */
.hi-admin-shell .hi-home-nav,
.hi-admin-shell .gcc-footer {
    display: none !important;
}
.hi-admin-shell {
    background: #f8fafc;
}
.hi-auth-seg:hover:not(.active) { color: #334155; background: rgba(226, 232, 240, 0.5); }
.hi-auth-seg.active {
    background: #ffffff;
    color: #1d4ed8;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(226, 232, 240, 0.5);
}

/* Hint text below segments / above form */
.hi-auth-hint {
    font-size: 14px;
    color: #64748b;
    margin: 0 0 20px;
    line-height: 1.55;
}

/* Fields */
.hi-auth-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 16px;
}
.hi-auth-grid--tight {
    gap: 14px;
    margin-bottom: 8px;
}
.hi-auth-section {
    margin: 18px 0 12px;
}
.hi-auth-section-title {
    font-size: 11px;
    font-weight: 800;
    color: #334155;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 0 0 10px;
}
.hi-auth-field-full { grid-column: 1 / -1; }
.hi-auth-fields {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 16px;
}
.hi-auth-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.hi-auth-field label {
    font-size: 11px;
    font-weight: 700;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-left: 2px;
}
.hi-auth-field input,
.hi-auth-field textarea,
.hi-auth-field select {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    font-size: 14px;
    color: #1e293b;
    background: rgba(248, 250, 252, 0.5);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    appearance: none;
    -webkit-appearance: none;
    font-family: inherit;
    box-sizing: border-box;
}
.hi-auth-field input::placeholder,
.hi-auth-field textarea::placeholder { color: #94a3b8; }
.hi-auth-field input:focus,
.hi-auth-field textarea:focus,
.hi-auth-field select:focus {
    outline: none;
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.10);
    background: #fff;
}
.hi-auth-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 40px;
}

/* Upload area */
.hi-auth-upload { position: relative; }
.hi-auth-upload input[type="file"] { display: none; }
.hi-auth-upload-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 24px;
    border: 2px dashed #cbd5e1;
    border-radius: 12px;
    background: #f8fafc;
    color: #64748b;
    cursor: pointer;
    transition: all 0.15s ease;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.hi-auth-upload-label:hover {
    border-color: #3b82f6;
    background: #eff6ff;
    color: #2563eb;
}
.hi-auth-upload-label:hover svg { transform: scale(1.1); }
.hi-auth-upload-label svg { transition: transform 0.15s ease; }
.hi-auth-upload.has-file .hi-auth-upload-label {
    border-color: #22c55e;
    background: #f0fdf4;
    color: #16a34a;
    border-style: solid;
}
.hi-auth-field-hint {
    font-size: 12px;
    color: #94a3b8;
    margin-top: 6px;
    text-align: center;
}

/* TOS */
.hi-auth-tos {
    margin: 20px 0 0;
    padding-top: 16px;
    border-top: 1px solid #f1f5f9;
}
.hi-auth-check-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    color: #64748b;
    cursor: pointer;
    line-height: 1.45;
}
.hi-auth-check-label--inline {
    align-items: center;
    gap: 10px;
    font-weight: 700;
    color: #0f172a;
}
.hi-auth-check-label input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 0;
    accent-color: #2563eb;
    flex-shrink: 0;
    cursor: pointer;
}
.hi-auth-check-label a {
    color: #2563eb;
    text-decoration: none;
    font-weight: 500;
}
.hi-auth-check-label a:hover { text-decoration: underline; }
.hi-auth-checkbox-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 12px 14px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #f8fafc;
}
.hi-auth-checkbox-card .hi-auth-field-hint {
    text-align: left;
    margin: 0;
}
.hi-auth-checkbox-card .hi-auth-check-label input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid #cbd5e1;
    border-radius: 6px;
    background: #fff;
    display: grid;
    place-content: center;
    transition: all 0.15s ease;
}
.hi-auth-checkbox-card .hi-auth-check-label input[type="checkbox"]::after {
    content: '';
    width: 10px;
    height: 6px;
    border: 2px solid #fff;
    border-top: 0;
    border-right: 0;
    transform: rotate(-45deg);
    opacity: 0;
    transition: opacity 0.15s ease;
}
.hi-auth-checkbox-card .hi-auth-check-label input[type="checkbox"]:checked {
    background: #2563eb;
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}
.hi-auth-checkbox-card .hi-auth-check-label input[type="checkbox"]:checked::after {
    opacity: 1;
}
.hi-auth-checkbox-card .hi-auth-check-label input[type="checkbox"]:checked + span {
    color: #1d4ed8;
}
.hi-auth-check-tag {
    align-self: flex-start;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #1d4ed8;
    background: rgba(37, 99, 235, 0.08);
    border: 1px solid rgba(37, 99, 235, 0.15);
    padding: 4px 8px;
    border-radius: 999px;
}

/* Submit */
.hi-auth-submit-row { margin-top: 20px; }
.hi-auth-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 32px;
    border-radius: 12px;
    font-family: inherit;
    font-weight: 600;
    font-size: 14px;
    background: #2563eb;
    border: none;
    color: #ffffff;
    cursor: pointer;
    transition: all 0.15s ease;
    box-shadow: 0 1px 3px rgba(37, 99, 235, 0.2);
}
.hi-auth-btn:hover {
    background: #1d4ed8;
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.25);
    transform: translateY(-1px);
}
.hi-auth-btn:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
.hi-auth-btn-text { transition: opacity 0.2s ease; }
.hi-auth-btn-loader { width: 20px; height: 20px; }

/* Messages */
.hi-auth-msg {
    margin-top: 16px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.04em;
    min-height: 20px;
}
.hi-auth-msg.success { color: #16a34a; }
.hi-auth-msg.error { color: #dc2626; }

/* Footer toggle */
.hi-auth-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 40px;
    border-top: 1px solid #f1f5f9;
    margin-top: 24px;
}
.hi-auth-footer-text { font-size: 14px; color: #64748b; margin: 0; }
.hi-auth-footer-link {
    font-size: 13px;
    font-weight: 700;
    color: #2563eb;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border: none;
    background: none;
    cursor: pointer;
    padding: 0;
    transition: color 0.15s ease;
}
.hi-auth-footer-link:hover { color: #1e40af; }

/* Type fields animation */
.hi-auth-type-fields {
    animation: hiAuthFieldsIn 0.25s ease-out;
}
@keyframes hiAuthFieldsIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Mobile */
@media (max-width: 640px) {
    .hi-auth-body { padding: 28px 20px 0; }
    .hi-auth-footer { padding: 16px 20px; }
    .hi-auth-grid { grid-template-columns: 1fr; }
    .hi-auth-seg { font-size: 12px; padding: 9px 4px; }
    .hi-auth-title { font-size: 22px; }
    .hi-auth-panel { border-radius: 12px; }
}

/* Legacy compat — keep .hi-form-grid for non-auth forms */
.hi-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 18px;
    margin-bottom: 20px;
}

/* ==================== PROFILE PAGE — Elegant v3 ====================
   Rewritten Apr 2026. Matches the home / opportunity / earned-badges
   aesthetic: light surface, white cards, HI blue accent, Poppins headings
   + Inter body, subtle shadows, ambient gradient hero. */

/* Page shell: reset duplicate padding definitions and set a clean base. */
.hi-profile-shell {
    min-height: 100vh;
    max-width: 1280px;
    margin: 0 auto;
    padding: 56px 28px 120px;
    background: transparent;
    font-family: 'Poppins', 'Inter', system-ui, -apple-system, sans-serif;
    color: #0f172a;
}

/* Soft ambient page background so the profile doesn't sit on a flat grey. */
body:has(.hi-profile-shell) {
    background:
        radial-gradient(ellipse 900px 420px at 15% 0%, rgba(0, 112, 243, 0.07), transparent 55%),
        radial-gradient(ellipse 700px 380px at 100% 10%, rgba(0, 112, 243, 0.04), transparent 60%),
        #f8fafc;
}

/* ========== HERO ========== */
.hi-profile-hero {
    position: relative;
    margin-bottom: 40px;
    padding: 40px 44px;
    border-radius: 24px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04), 0 20px 50px rgba(15, 23, 42, 0.05);
    display: flex;
    flex-direction: column;
    gap: 24px;
    overflow: hidden;
    isolation: isolate;
}

/* Ambient brand gradient wash inside the hero card */
.hi-profile-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(ellipse 500px 280px at 100% 0%, rgba(0, 112, 243, 0.10), transparent 60%),
        radial-gradient(ellipse 400px 240px at 0% 100%, rgba(0, 112, 243, 0.05), transparent 60%);
    pointer-events: none;
}

.hi-profile-identity {
    display: flex;
    align-items: center;
    gap: 28px;
}

/* Avatar with blue ring + subtle glow */
.hi-profile-avatar {
    position: relative;
    width: 120px;
    height: 120px;
    border-radius: 28px;
    background-size: cover;
    background-position: center;
    display: grid;
    place-items: center;
    font-family: 'Poppins', sans-serif;
    font-size: 42px;
    font-weight: 700;
    color: #ffffff;
    background-color: #0070f3;
    background-image: linear-gradient(135deg, #0070f3, #005bb5);
    box-shadow:
        0 0 0 4px #ffffff,
        0 0 0 5px rgba(0, 112, 243, 0.25),
        0 14px 30px rgba(0, 112, 243, 0.2);
    overflow: hidden;
    flex-shrink: 0;
}

.hi-profile-avatar::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.15), transparent 60%);
    pointer-events: none;
}

.hi-profile-avatar--large {
    width: 154px;
    height: 154px;
    border-radius: 44px;
}

.hi-profile-avatar span {
    position: relative;
    z-index: 1;
}

.hi-profile-avatar-field {
    display: flex;
    align-items: flex-start;
    gap: 28px;
    margin-bottom: 28px;
}

.hi-upload-controls {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.hi-upload-pill {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px 10px 16px;
    border-radius: 999px;
    border: 1px solid var(--hi-border, #E2E8F0);
    background: #FFFFFF;
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    font-size: 13px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--hi-text, #0F172A);
    overflow: hidden;
}

.hi-upload-pill::before {
    content: '';
    width: 28px;
    height: 28px;
    border-radius: 10px;
    background: var(--hi-surface, #F8FAFC);
    border: 1px solid var(--hi-border, #E2E8F0);
    display: inline-block;
    mask-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' y1='3' x2='12' y2='15'/%3E%3C/svg%3E");
    mask-repeat: no-repeat;
    mask-position: center;
    margin-right: 6px;
}

.hi-upload-hint {
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-upload-pill input[type="file"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.hi-upload-pill:hover {
    border-color: var(--hi-blue, #2563EB);
    color: var(--hi-navy, #0D1B2A);
}

.hi-upload-pill:focus-within {
    outline: 2px solid rgba(37, 99, 235, 0.3);
    outline-offset: 3px;
}

/* Hero typography — Poppins display for the user's name */
.hi-profile-hero .gcc-section-label {
    color: #0070f3;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 8px;
}

.hi-profile-identity h1 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.8rem, 3.2vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -0.025em;
    line-height: 1.15;
    color: #0f172a;
    margin: 0 0 6px;
}

.hi-profile-tagline {
    margin: 6px 0 14px;
    color: #475569;
    font-family: 'Inter', sans-serif;
    font-size: 16px;
    line-height: 1.5;
}

/* Meta row: flat vertical-rhythm chips (e.g. "BASE: Bangalore") */
.hi-profile-meta {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
}

.hi-profile-meta li {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: #f1f5f9;
    border: 1px solid rgba(15, 23, 42, 0.05);
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    color: #334155;
}

.hi-profile-meta span {
    color: #64748b;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.hi-profile-meta a {
    color: #0070f3;
    text-decoration: none;
    font-weight: 500;
}
.hi-profile-meta a:hover { text-decoration: underline; }

/* Actions: sit below identity, clean row of CTAs */
.hi-profile-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
    padding-top: 24px;
    border-top: 1px solid rgba(15, 23, 42, 0.06);
}

/* ========== CONTENT GRID + CARDS ========== */
.hi-profile-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
}

.hi-profile-card {
    position: relative;
    padding: 28px 28px 26px;
    border-radius: 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.hi-profile-card:hover {
    border-color: rgba(0, 112, 243, 0.2);
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.06);
    transform: translateY(-2px);
}

/* Highlight card — subtle blue wash with stronger accent edge */
.hi-profile-card--highlight {
    background: linear-gradient(135deg, #f0f7ff 0%, #ffffff 60%);
    border-color: rgba(0, 112, 243, 0.18);
    box-shadow: 0 2px 8px rgba(0, 112, 243, 0.06);
}

.hi-profile-card--highlight::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    border-radius: 18px 18px 0 0;
    background: linear-gradient(90deg, #0070f3, rgba(0, 112, 243, 0));
}

.hi-profile-card--wide {
    grid-column: span 2;
}

.hi-profile-card h2 {
    font-family: 'Poppins', sans-serif;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.015em;
    color: #0f172a;
    margin: 0;
}

.hi-profile-card > p {
    font-family: 'Inter', sans-serif;
    font-size: 14.5px;
    line-height: 1.65;
    color: #475569;
    margin: 12px 0 0;
}

.hi-card-heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

/* Two-column label/value list used by recruiter firm-story & talent metadata */
.hi-profile-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.hi-profile-list li {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 10px 0;
    border-bottom: 1px dashed rgba(15, 23, 42, 0.06);
}
.hi-profile-list li:last-child { border-bottom: none; }

.hi-profile-list span {
    font-family: 'Inter', sans-serif;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #64748b;
}

.hi-profile-list strong {
    color: #0f172a;
    font-weight: 600;
    font-size: 14.5px;
    font-family: 'Inter', sans-serif;
}

.hi-profile-list--cols {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0 24px;
}

/* Focus pill tray */
.hi-pill-tray {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 16px;
}

.hi-chip {
    padding: 5px 12px;
    border-radius: 6px;
    background: #f1f5f9;
    border: 1px solid rgba(15, 23, 42, 0.05);
    font-family: 'Inter', sans-serif;
    font-size: 11.5px;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: none;
    color: #334155;
}

.hi-profile-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #0070f3;
    font-family: 'Inter', sans-serif;
    font-weight: 600;
    text-decoration: none;
    font-size: 13px;
    letter-spacing: 0.02em;
    transition: color 0.15s ease;
}
.hi-profile-link::after {
    content: '→';
    transition: transform 0.2s ease;
}
.hi-profile-link:hover {
    color: #005bb5;
}
.hi-profile-link:hover::after {
    transform: translateX(3px);
}

@media (max-width: 768px) {
    .hi-profile-hero {
        padding: 24px;
    }
    .hi-profile-identity {
        flex-direction: column;
        align-items: flex-start;
    }
    .hi-profile-grid {
        grid-template-columns: 1fr;
    }
    .hi-profile-card--wide {
        grid-column: span 1;
    }
}

@media (max-width: 640px) {
    .hi-profile-actions {
        flex-direction: column;
        width: 100%;
    }
    .hi-profile-actions .gcc-btn-secondary {
        width: 100%;
        justify-content: center;
    }
}

.gcc-hire-form {
    display: flex;
    flex-direction: column;
}

.gcc-form-group { margin-bottom: 24px; }
.gcc-form-group label { 
    display: block; 
    color: var(--hi-text-sec, #475569); 
    margin-bottom: 8px; 
    font-size: 13px; 
    font-weight: 600; 
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.gcc-form-group input, .gcc-form-group textarea, .gcc-form-group select {
    width: 100%;
    padding: 14px 16px;
    background: var(--input-bg);
    border: 1.5px solid var(--input-border);
    color: var(--input-text);
    border-radius: var(--radius-md);
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-size: 15px;
    transition: all 0.15s ease;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.gcc-form-group input {
    height: 52px;
}

.gcc-form-group select {
    height: 52px;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 44px;
}

.gcc-form-group select:hover {
    border-color: var(--hi-border-strong, #CBD5E1);
    background-color: var(--hi-surface, #F8FAFC);
}

.gcc-form-group textarea {
    min-height: 140px;
    resize: vertical;
    line-height: 1.6;
}

.gcc-form-group input::placeholder, .gcc-form-group textarea::placeholder {
    color: var(--hi-text-muted, #94A3B8);
    font-weight: 400;
}

.gcc-form-group input:hover, .gcc-form-group textarea:hover {
    border-color: var(--hi-border-strong, #CBD5E1);
    background: var(--hi-surface, #F8FAFC);
}

.gcc-form-group input:focus, .gcc-form-group textarea:focus, .gcc-form-group select:focus {
    outline: none;
    border-color: var(--hi-blue, #2563EB);
    background: var(--input-bg-focus);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
    transform: translateY(-1px);
}

.gcc-btn-submit {
    width: 100%;
    padding: 16px;
    background: var(--hi-blue, #2563EB);
    color: #FFFFFF;
    border: none;
    border-radius: var(--radius-sm);
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    transition: all 0.15s ease;
    box-shadow: 0 4px 16px rgba(37, 99, 235, 0.25);
}

.gcc-btn-submit:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.35);
    background: var(--hi-blue-mid, #3B82F6);
}

.gcc-btn-submit:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.gcc-btn-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.gcc-btn-submit .btn-loader {
    width: 16px;
    height: 16px;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-top-color: rgba(255, 255, 255, 0.9);
    display: none;
    animation: spin 0.8s linear infinite;
}

.gcc-btn-submit.is-loading .btn-text {
    opacity: 0.85;
}

.gcc-btn-submit.is-loading .btn-loader {
    display: inline-block;
}

.gcc-form-message {
    margin-top: 14px;
    font-size: 14px;
    color: var(--hi-text-sec, #475569);
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Animations */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* ==================== OPPORTUNITY DIRECTORY PAGE ==================== */
.hi-page-opportunity-directory {
    min-height: 100vh;
    background: var(--hi-surface, #F8FAFC);
}

/* Light mode is now the only mode — legacy overrides removed */

.hi-opportunity-hero {
    padding: 120px 0 80px;
    text-align: left;
}

.hi-opportunity-hero-content {
    max-width: 100%;
}

.hi-single-hero {
    position: relative;
    text-align: center;
    padding: 140px 0 100px;
    overflow: hidden;
    isolation: isolate;
}

.hi-single-hero::before,
.hi-single-hero::after {
    display: none;
}

.hi-single-hero-inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 48px 40px 56px;
    border-radius: var(--radius-xl);
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
    box-shadow: var(--shadow-xl);
}

.hi-hero-pill-row {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}

.hi-hero-pill-row .hi-pill {
    margin-bottom: 0;
}

.hi-hero-pill-row .hi-status {
    padding: 6px 16px;
}

.hi-single-hero h1 {
    font-size: clamp(2.4rem, 4.2vw, 3.8rem);
    letter-spacing: -0.02em;
    margin-bottom: 10px;
}

.hi-hero-company {
    font-size: 1.1rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-hero-divider {
    width: 120px;
    height: 2px;
    margin: 28px auto 32px;
    background: linear-gradient(90deg, transparent, var(--hi-blue, #2563EB), transparent);
}

.hi-hero-data-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 18px;
    margin-bottom: 36px;
}

.hi-hero-data-card {
    padding: 18px 20px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--hi-border, #E2E8F0);
    background: var(--hi-surface, #F8FAFC);
    box-shadow: var(--shadow-sm);
}

.hi-hero-data-label {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--hi-text-muted, #94A3B8);
    margin-bottom: 4px;
}

.hi-hero-data-value {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--hi-navy, #0D1B2A);
    margin: 0;
}

.hi-opportunity-title {
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: 42px;
    font-weight: 700;
    margin: 16px 0 16px;
    color: var(--hi-navy, #0D1B2A);
    letter-spacing: -0.03em;
}

.hi-opportunity-subtitle {
    font-size: 16px;
    color: var(--hi-text-sec, #475569);
    line-height: 1.6;
    max-width: 700px;
    margin: 0 0 32px;
}

.hi-hero-search {
    width: 100%;
    margin-top: 32px;
}

.hi-hero-search-form {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    border-radius: var(--radius-lg);
    border: 1px solid var(--hi-border, #E2E8F0);
    background: #FFFFFF;
    box-shadow: var(--shadow-lg);
}

.hi-search-icon {
    position: absolute;
    left: 20px;
    color: var(--hi-text-muted, #94A3B8);
    pointer-events: none;
    z-index: 2;
}

.hi-hero-search-input {
    width: 100%;
    padding: 20px 148px 20px 60px;
    background: transparent;
    border: none;
    color: var(--hi-text, #0F172A);
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-size: 16px;
    transition: all 0.15s ease;
}

.hi-hero-search-input:focus {
    outline: none;
    box-shadow: none;
}

.hi-hero-search-input::placeholder {
    color: var(--hi-text-muted, #94A3B8);
}

.hi-hero-search-btn {
    position: absolute;
    right: 10px;
    padding: 14px 26px;
    background: var(--hi-blue, #2563EB);
    border: none;
    border-radius: var(--radius-sm);
    color: #FFFFFF;
    font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s ease;
    display: flex;
    align-items: center;
    gap: 8px;
}

.hi-hero-search-btn:hover {
    background: var(--hi-blue-mid, #3B82F6);
    transform: translateX(2px);
}

.hi-opportunity-hero {
    position: relative;
    overflow: hidden;
}

.hi-opportunity-hero::after {
    display: none;
}

.hi-hero-broadcast {
    margin-top: 18px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px;
    border-radius: 999px;
    background: var(--hi-blue-pale, #EFF6FF);
    border: 1px solid var(--hi-blue-light, #DBEAFE);
    color: var(--hi-blue, #2563EB);
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 13px;
}

.hi-hero-broadcast-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 2px solid rgba(37, 99, 235, 0.3);
    background: var(--hi-blue, #2563EB);
    box-shadow: 0 0 8px rgba(37, 99, 235, 0.5);
    animation: heroPulse 2.5s ease-in-out infinite;
}

.hi-hero-metrics {
    margin-top: 36px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 18px;
}

.hi-hero-metric {
    padding: 18px;
    border-radius: var(--radius-lg);
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
    box-shadow: var(--shadow-sm);
}

.hi-hero-metric-label {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-hero-metric-value {
    display: block;
    font-family: var(--font-display, 'Sora', sans-serif);
    font-size: 28px;
    font-weight: 700;
    margin: 4px 0;
    color: var(--hi-navy, #0D1B2A);
}

.hi-hero-metric-meta {
    font-size: 13px;
    color: var(--hi-text-sec, #475569);
}

.hi-hero-metrics-bar {
    padding: 24px 0 0;
}

.hi-hero-metrics--bar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}

.hi-hero-metrics--bar .hi-hero-metric {
    padding: 14px 16px;
    border-radius: var(--radius-lg);
    background: #FFFFFF;
}

.hi-hero-metrics--bar .hi-hero-metric-value {
    font-size: 26px;
}

.hi-hero-metrics--bar .hi-hero-metric-meta {
    font-size: 12px;
}

.hi-hero-tags {
    margin-top: 28px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.hi-hero-tags-label {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 12px;
    letter-spacing: 0.1em;
    color: var(--hi-text-muted, #94A3B8);
    text-transform: uppercase;
}

.hi-hero-tags-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.hi-hero-tag {
    border: 1px solid var(--hi-border, #E2E8F0);
    border-radius: 999px;
    padding: 8px 16px;
    background: #FFFFFF;
    color: var(--hi-text-sec, #475569);
    font-size: 13px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.15s ease;
}

.hi-hero-tag:hover {
    border-color: var(--hi-blue, #2563EB);
    color: var(--hi-blue, #2563EB);
    transform: translateY(-1px);
}

.hi-hero-tag.active {
    background: var(--hi-blue, #2563EB);
    border-color: transparent;
    color: #FFFFFF;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}

.hi-hero-actions {
    justify-content: center;
}

.hi-opportunity-container {
    padding-bottom: 100px;
    position: relative;
    z-index: 1;
}

.hi-filter-bar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 18px;
    margin-bottom: 32px;
    padding: 24px 28px;
    border-radius: var(--radius-xl);
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
    box-shadow: var(--shadow-lg);
}

.hi-filter-bar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
}

.hi-filter-bar-label {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-filter-bar-hint {
    font-size: 13px;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.hi-active-filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: var(--hi-blue-pale, #EFF6FF);
    border: 1px solid var(--hi-blue-light, #DBEAFE);
    border-radius: var(--radius-sm);
    color: var(--hi-blue, #2563EB);
    font-size: 13px;
    animation: slideIn 0.2s ease;
}

.hi-active-filter-tag button {
    background: none;
    border: none;
    color: inherit;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
}

.hi-opportunity-layout {
    display: grid;
    grid-template-columns: minmax(240px, 1fr) minmax(0, 3.2fr);
    gap: 36px;
    align-items: start;
    position: relative;
}

/* Sidebar Filters */
.hi-opportunity-sidebar {
    position: sticky;
    top: 90px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 24px;
    border-radius: var(--radius-xl);
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
    box-shadow: var(--shadow-lg);
}

.hi-filter-section {
    margin-bottom: 0;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--hi-border, #E2E8F0);
}

.hi-filter-title {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--hi-text-muted, #94A3B8);
    margin: 0 0 12px;
}

.hi-filter-pills {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.hi-filter-pill {
    padding: 10px 16px;
    background: transparent;
    border: 1px solid var(--hi-border, #E2E8F0);
    border-radius: var(--radius-sm);
    color: var(--hi-text-sec, #475569);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    text-align: left;
    white-space: nowrap;
}

.hi-filter-pill:hover {
    background: var(--hi-blue-pale, #EFF6FF);
    border-color: var(--hi-blue-light, #DBEAFE);
    color: var(--hi-blue, #2563EB);
}

.hi-filter-pill.active {
    background: var(--hi-blue-pale, #EFF6FF);
    border-color: var(--hi-blue, #2563EB);
    color: var(--hi-blue, #2563EB);
    font-weight: 600;
}

.hi-search-form {
    position: relative;
    display: flex;
    align-items: center;
}

.hi-search-input {
    width: 100%;
    padding: 12px 40px 12px 16px;
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    border-radius: 12px;
    color: var(--input-text);
    font-size: 14px;
    transition: all 0.3s ease;
}

.hi-search-input:focus {
    outline: none;
    border-color: var(--hi-blue, #2563EB);
    background: var(--input-bg-focus);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.hi-search-input::placeholder {
    color: var(--hi-text-muted, #94A3B8);
}

.hi-search-btn {
    position: absolute;
    right: 8px;
    background: none;
    border: none;
    padding: 8px;
    color: var(--hi-text-muted, #94A3B8);
    cursor: pointer;
    transition: color 0.15s ease;
}

.hi-search-btn:hover {
    color: var(--hi-blue, #2563EB);
}

.hi-filter-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.hi-filter-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background 0.15s ease;
    font-size: 14px;
    color: var(--hi-text, #0F172A);
}

.hi-filter-item:hover {
    background: var(--hi-surface, #F8FAFC);
}

.hi-filter-checkbox {
    width: 16px;
    height: 16px;
    border: 2px solid var(--hi-border-strong, #CBD5E1);
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s ease;
    appearance: none;
    background: #FFFFFF;
    position: relative;
}

.hi-filter-checkbox:checked {
    background: var(--hi-blue, #2563EB);
    border-color: var(--hi-blue, #2563EB);
}

.hi-filter-checkbox:checked::after {
    content: '';
    position: absolute;
    left: 4px;
    top: 1px;
    width: 4px;
    height: 8px;
    border: solid #FFFFFF;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.hi-filter-item span:first-of-type {
    flex: 1;
}

.hi-filter-count {
    font-size: 12px;
    color: var(--hi-text-muted, #94A3B8);
    background: var(--hi-surface, #F8FAFC);
    padding: 2px 8px;
    border-radius: 12px;
}


.hi-filter-reset {
    padding: 8px 18px;
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
    border-radius: 999px;
    color: var(--hi-text-sec, #475569);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    letter-spacing: 0.01em;
}

.hi-filter-reset:hover {
    background: #FEF2F2;
    border-color: #FECACA;
    color: #DC2626;
}

.hi-filter-reset:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.15);
}

.hi-filter-reset svg {
    width: 14px;
    height: 14px;
    opacity: 0.9;
}

.hi-filter-reset--inline {
    padding: 8px 18px;
    border-radius: 999px;
    font-size: 13px;
}

.hi-filter-reset svg {
    width: 14px;
    height: 14px;
}

/* Main Content Area */
.hi-opportunity-main {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.hi-opportunity-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    padding: 18px 24px;
    margin-bottom: 8px;
    border-radius: var(--radius-lg);
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
}

.hi-controls-actions {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.hi-results-count {
    font-size: 13px;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-sort-controls {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 8px 16px;
    border-radius: 999px;
    background: var(--hi-surface, #F8FAFC);
    border: 1px solid var(--hi-border, #E2E8F0);
}

.hi-sort-controls label {
    font-size: 13px;
    color: var(--hi-text-sec, #475569);
    font-weight: 500;
}

.hi-sort-select {
    padding: 6px 32px 6px 12px;
    background: #FFFFFF;
    border: 1.5px solid var(--hi-border, #E2E8F0);
    border-radius: 999px;
    color: var(--hi-text, #0F172A);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.15s ease;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%2394A3B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.hi-sort-select:hover {
    border-color: var(--hi-border-strong, #CBD5E1);
}

.hi-sort-select:focus {
    outline: none;
    border-color: var(--hi-blue, #2563EB);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
    transform: translateY(-1px);
}

/* Opportunities Grid */
.hi-opportunities-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.hi-opportunity-card {
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
    border-radius: var(--radius-xl);
    padding: 24px;
    transition: all 0.15s ease;
    display: flex;
    flex-direction: column;
    gap: 16px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.hi-opportunity-card::before {
    display: none;
}

.hi-opportunity-card:hover {
    transform: translateY(-2px);
    border-color: var(--hi-blue, #2563EB);
    box-shadow: var(--shadow-lg);
}

.hi-opportunity-card:hover::before {
    display: none;
}

.hi-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.hi-card-category {
    font-family: var(--font-mono, 'Inter', 'Poppins', system-ui, sans-serif);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--hi-blue, #2563EB);
    background: var(--hi-blue-pale, #EFF6FF);
    padding: 4px 10px;
    border-radius: var(--radius-sm);
}

.hi-card-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.4;
}

.hi-card-title a {
    color: var(--hi-navy, #0D1B2A);
    text-decoration: none;
    transition: color 0.15s ease;
}

.hi-card-title a:hover {
    color: var(--hi-blue, #2563EB);
}

.hi-card-company {
    font-size: 13px;
    color: var(--hi-text-muted, #94A3B8);
    margin: 0;
}

.hi-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 10px 0;
    border-top: 1px solid var(--hi-border, #E2E8F0);
}

.hi-card-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--hi-text-sec, #475569);
}

.hi-card-meta-item svg {
    width: 14px;
    height: 14px;
    color: var(--hi-text-muted, #94A3B8);
}

.hi-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.hi-tag {
    font-size: 12px;
    padding: 4px 10px;
    background: var(--hi-blue-pale, #EFF6FF);
    border: 1px solid var(--hi-blue-light, #DBEAFE);
    border-radius: var(--radius-sm);
    color: var(--hi-blue, #2563EB);
}

.hi-tag-more {
    background: var(--hi-surface, #F8FAFC);
    border-color: var(--hi-border, #E2E8F0);
    color: var(--hi-text-muted, #94A3B8);
}

.hi-card-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--hi-blue, #2563EB);
    text-decoration: none;
    margin-top: auto;
    transition: all 0.15s ease;
}

.hi-card-link:hover {
    color: var(--hi-navy, #0D1B2A);
    gap: 10px;
}

.hi-card-link svg {
    width: 14px;
    height: 14px;
    transition: transform 0.2s ease;
}

.hi-card-link:hover svg {
    transform: translateX(3px);
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateX(-10px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Empty State */
.hi-empty-state {
    grid-column: 1 / -1;
    text-align: center;
    padding: 80px 20px;
    color: var(--hi-text-sec, #475569);
}

.hi-empty-state svg {
    margin: 0 auto 24px;
    opacity: 0.3;
}

.hi-empty-state h3 {
    font-size: 24px;
    color: var(--hi-navy, #0D1B2A);
    margin: 0 0 12px;
}

.hi-empty-state p {
    font-size: 16px;
    margin: 0;
}

/* Pagination */
.hi-pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 40px;
}

.hi-pagination a,
.hi-pagination span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: #FFFFFF;
    border: 1px solid var(--hi-border, #E2E8F0);
    border-radius: var(--radius-sm);
    color: var(--hi-text-sec, #475569);
    text-decoration: none;
    font-size: 14px;
    transition: all 0.15s ease;
}

.hi-pagination a:hover {
    background: var(--hi-blue-pale, #EFF6FF);
    border-color: var(--hi-blue-light, #DBEAFE);
    color: var(--hi-blue, #2563EB);
}

.hi-pagination .current {
    background: var(--hi-blue, #2563EB);
    border-color: var(--hi-blue, #2563EB);
    color: #FFFFFF;
    font-weight: 600;
}

/* Responsive */
@media (max-width: 1024px) {
    .hi-opportunity-layout {
        grid-template-columns: 1fr;
    }

    .hi-opportunity-sidebar {
        position: static;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 16px;
    }

    .hi-opportunities-grid {
        grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    }
}

@media (max-width: 768px) {
    .hi-opportunity-hero {
        padding: 100px 20px 60px;
    }

    .hi-filter-bar-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .hi-filter-bar {
        padding: 20px;
    }

    .hi-controls-actions {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
    }

    .hi-filter-reset--inline {
        width: 100%;
        justify-content: center;
    }

    .hi-opportunity-title {
        font-size: 32px;
    }

    .hi-hero-search-input {
        padding: 14px 120px 14px 44px;
    }

    .hi-opportunity-controls {
        flex-direction: column;
        gap: 12px;
        align-items: flex-start;
    }

    .hi-sort-controls {
        width: 100%;
        justify-content: space-between;
    }

    .hi-opportunities-grid {
        grid-template-columns: 1fr;
    }

    .hi-opportunity-sidebar {
        grid-template-columns: 1fr;
    }
}

/* ==================== RESUME TAILOR HIC COIN UI ==================== */
.hrt-coin-info {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 16px;
}

.hrt-coin-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: rgba(16, 185, 129, 0.15);
    color: #10b981;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    border: 1px solid rgba(16, 185, 129, 0.3);
    transition: all 0.3s ease;
}

.hrt-coin-badge--low {
    background: rgba(239, 68, 68, 0.15);
    color: #ef4444;
    border-color: rgba(239, 68, 68, 0.3);
}

.hrt-coin-cost {
    font-size: 13px;
    color: var(--color-text-secondary);
    font-weight: 500;
}

.hrt-coin-warning {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 12px 20px;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 10px;
    color: #ef4444;
    font-size: 14px;
    margin-bottom: 16px;
}

.hrt-coin-warning a {
    color: #ef4444;
    font-weight: 600;
    text-decoration: underline;
}

.hrt-coin-warning a:hover {
    color: #dc2626;
}

/* ==================== RESUME TAILOR EDITOR OPTIONS ==================== */
.hrt-editor-options {
    padding: 80px 0;
    background: var(--color-bg-secondary);
}

.hrt-options-card {
    background: var(--color-bg-primary);
    border-radius: 16px;
    padding: 48px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--color-border);
}

.hrt-options-header {
    text-align: center;
    margin-bottom: 48px;
}

.hrt-options-title {
    font-size: 32px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 16px;
}

.hrt-options-subtitle {
    font-size: 18px;
    color: var(--color-text-secondary);
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.6;
}

.hrt-options-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    margin-bottom: 48px;
}

.hrt-option-item {
    display: flex;
    gap: 24px;
    padding: 32px;
    background: var(--color-bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--color-border);
    transition: all 0.3s ease;
}

.hrt-option-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.hrt-option-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    background: var(--color-accent);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}

.hrt-option-text h4 {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: 12px;
}

.hrt-option-text p {
    font-size: 16px;
    color: var(--color-text-secondary);
    margin-bottom: 20px;
    line-height: 1.6;
}

.hrt-option-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--color-accent);
    text-decoration: none;
    font-weight: 600;
    font-size: 16px;
    transition: all 0.2s ease;
}

.hrt-option-link:hover {
    color: var(--color-accent-dark);
    transform: translateX(4px);
}

.hrt-tips-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.hrt-tips-list li {
    position: relative;
    padding-left: 24px;
    margin-bottom: 12px;
    font-size: 15px;
    color: var(--color-text-secondary);
    line-height: 1.5;
}

.hrt-tips-list li:before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--color-accent);
    font-weight: 600;
}

.hrt-options-footer {
    text-align: center;
    padding-top: 32px;
    border-top: 1px solid var(--color-border);
}

.hrt-beta-note {
    font-size: 15px;
    color: var(--color-text-secondary);
    background: rgba(255, 193, 7, 0.1);
    padding: 16px 24px;
    border-radius: 8px;
    border-left: 4px solid #ffc107;
    display: inline-block;
}

.hrt-beta-note strong {
    color: var(--color-text-primary);
}

/* Responsive Design */
@media (max-width: 968px) {
    .hrt-options-content {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    
    .hrt-option-item {
        padding: 24px;
        gap: 20px;
    }
    
    .hrt-options-card {
        padding: 32px 24px;
    }
}

@media (max-width: 640px) {
    .hrt-editor-options {
        padding: 60px 0;
    }
    
    .hrt-options-title {
        font-size: 28px;
    }
    
    .hrt-options-subtitle {
        font-size: 16px;
    }
    
    .hrt-option-item {
        flex-direction: column;
        text-align: center;
        padding: 24px 20px;
    }
    
    .hrt-option-icon {
        margin: 0 auto 16px;
    }
    
    .hrt-options-card {
        padding: 24px 20px;
    }
}
