        /* ============================================
           STANDARDIZED COLOR SCHEME (Brand Colors v2)
           ============================================ */
        :root {
            --scaffold: #0D0F1A;
            --bg-dark: #0D0F1A;
            --bg-main: #1A1D29;
            --bg-card: #2A3040;
            --surface: #2A3040;
            --bg-input: rgba(0,0,0,0.3);

            --blue: #00d4ff;
            --cyan: #00d4ff;
            --cyan-dim: rgba(0, 212, 255, 0.15);
            --green: #00c853;
            --green-dim: rgba(0, 200, 83, 0.15);
            --yellow: #ffd600;
            --yellow-dim: rgba(255, 214, 0, 0.15);
            --orange: #FF9800;
            --orange-dim: rgba(255, 152, 0, 0.15);
            --red: #d32f2f;
            --red-dim: rgba(211, 47, 47, 0.15);
            --purple: #a855f7;
            --purple-dim: rgba(168, 85, 247, 0.15);

            --text-primary: #E4E4F0;
            --text-secondary: #B0B0C8;
            --text-muted: #999999;
            --text-dim: #666666;

            --border-light: rgba(255,255,255,0.08);
            --border-medium: #333;

            --pro-green: #4caf50;
            --pro-green-dim: rgba(76, 175, 80, 0.15);
        }

        * { margin: 0; padding: 0; box-sizing: border-box; }
        
        body {
            background: var(--bg-main);
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
            min-height: 100vh;
            color: var(--text-primary);
        }

        /* ============================================
           LAYOUT & CONTAINERS
           ============================================ */
        .app-container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 20px;
        }

        .page { display: none; }
        .page.active { display: block; }
        
        /* Hide pro-only pages in client view */
        body.client-view #page-opportunities { display: none !important; }
        body.client-view #page-settings { display: none !important; }

        /* ============================================
           MAIN HEADER (Pro Dashboard)
           ============================================ */
        .main-header {
            background: var(--bg-dark);
            border-bottom: 1px solid var(--border-light);
            padding: 12px 20px;
            position: sticky;
            top: 0;
            z-index: 100;
        }

        .header-content {
            max-width: 1200px;
            margin: 0 auto;
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 16px;
        }

        .header-left {
            display: flex;
            align-items: center;
            gap: 16px;
        }

        .logo {
            display: flex;
            flex-direction: column;
        }

        .logo-text {
            font-size: 18px;
            font-weight: 800;
            color: var(--pro-green);
        }

        .logo-sub {
            font-size: 10px;
            color: var(--text-muted);
        }

        .logo-sub span {
            color: var(--cyan);
            font-weight: 600;
        }

        /* View Toggle */
        .view-toggle {
            display: flex;
            background: var(--bg-card);
            border-radius: 8px;
            padding: 3px;
        }

        .view-toggle-btn {
            padding: 8px 16px;
            border: none;
            background: transparent;
            color: var(--text-muted);
            font-size: 13px;
            font-weight: 500;
            cursor: pointer;
            border-radius: 6px;
            transition: all 0.2s;
        }

        .view-toggle-btn.active {
            background: var(--pro-green);
            color: #000;
        }

        .view-toggle-btn.client-btn.active {
            background: var(--cyan);
        }

        /* Header Right */
        .header-right {
            display: flex;
            align-items: center;
            gap: 16px;
        }

        .credits-display {
            display: flex;
            visibility: hidden;
            align-items: center;
            gap: 8px;
            background: var(--cyan-dim);
            border: 1px solid rgba(0, 212, 255, 0.3);
            padding: 6px 12px;
            border-radius: 20px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .credits-display:hover {
            background: rgba(0, 212, 255, 0.25);
        }

        .credits-display.low {
            background: var(--yellow-dim);
            border-color: rgba(255, 180, 0, 0.3);
        }

        .credits-display.low .credits-value {
            color: var(--yellow);
        }

        .credits-icon {
            font-size: 14px;
        }

        .credits-value {
            font-size: 13px;
            font-weight: 600;
            color: var(--cyan);
        }

        .credits-label {
            font-size: 11px;
            color: var(--text-muted);
        }

        .user-avatar {
            width: 36px;
            height: 36px;
            border-radius: 50%;
            background: linear-gradient(135deg, var(--pro-green), #2e7d32);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 14px;
            font-weight: 700;
            cursor: pointer;
        }

        /* ============================================
           DEMO CONTROLS (for testing)
           ============================================ */
        .demo-controls {
            background: var(--bg-dark);
            border: 1px solid var(--border-medium);
            border-radius: 10px;
            padding: 12px 16px;
            margin-bottom: 20px;
            display: flex;
            flex-wrap: wrap;
            gap: 16px;
            align-items: center;
        }

        .demo-control {
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 12px;
        }

        .demo-control label {
            color: var(--text-muted);
        }

        .demo-control select {
            background: var(--bg-card);
            border: 1px solid var(--border-medium);
            color: var(--text-primary);
            padding: 6px 10px;
            border-radius: 6px;
            font-size: 12px;
        }

        .demo-badge {
            background: var(--purple);
            color: #000;
            font-size: 10px;
            font-weight: 700;
            padding: 4px 10px;
            border-radius: 10px;
        }

        /* ============================================
           PRO VIEW - CLIENT LIST
           ============================================ */
        .page-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            margin-bottom: 24px;
            flex-wrap: wrap;
            gap: 16px;
        }

        .page-title {
            font-size: 24px;
            font-weight: 700;
        }

        .page-subtitle {
            font-size: 13px;
            color: var(--text-muted);
            margin-top: 4px;
        }

        /* Stats Grid */
        .stats-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 12px;
            margin-bottom: 24px;
        }

        .stat-card {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 16px;
            text-align: center;
        }

        .stat-card.clickable {
            cursor: pointer;
            transition: all 0.2s ease;
            border: 1px solid transparent;
        }

        .stat-card.clickable:hover {
            border-color: var(--cyan);
            transform: translateY(-2px);
        }

        .stat-value {
            font-size: 28px;
            font-weight: 800;
            color: var(--cyan);
        }

        .stat-value.green { color: var(--green); }
        .stat-value.yellow { color: var(--yellow); }
        .stat-value.purple { color: var(--purple); }
        .stat-value.red { color: var(--red); }

        .stat-label {
            font-size: 11px;
            color: var(--text-muted);
            text-transform: uppercase;
            margin-top: 4px;
        }

        /* Search Bar */
        .search-bar {
            display: flex;
            align-items: center;
            gap: 12px;
            background: var(--bg-card);
            border: 1px solid var(--border-medium);
            border-radius: 10px;
            padding: 12px 16px;
            margin-bottom: 16px;
        }

        .search-bar input {
            flex: 1;
            background: transparent;
            border: none;
            color: var(--text-primary);
            font-size: 14px;
            outline: none;
        }

        .search-bar input::placeholder {
            color: var(--text-dim);
        }

        /* Client Table (Desktop) */
        .clients-table {
            width: 100%;
            border-collapse: collapse;
            background: var(--bg-card);
            border-radius: 12px;
            overflow: hidden;
        }

        .clients-table th {
            text-align: left;
            padding: 14px 16px;
            font-size: 11px;
            font-weight: 600;
            color: var(--text-muted);
            text-transform: uppercase;
            background: rgba(0,0,0,0.2);
            border-bottom: 1px solid var(--border-light);
        }

        .clients-table td {
            padding: 14px 16px;
            font-size: 14px;
            border-bottom: 1px solid var(--border-light);
        }

        .clients-table tr:last-child td {
            border-bottom: none;
        }

        .clients-table tbody tr {
            cursor: pointer;
            transition: background 0.2s;
        }

        .clients-table tbody tr:hover {
            background: rgba(255,255,255,0.03);
        }

        .client-name-cell {
            display: flex;
            align-items: center;
            gap: 12px;
        }

        .client-avatar-sm {
            width: 36px;
            height: 36px;
            border-radius: 50%;
            background: var(--cyan-dim);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
            font-weight: 600;
            color: var(--cyan);
        }

        .client-name {
            font-weight: 600;
        }

        .client-email {
            font-size: 12px;
            color: var(--text-muted);
        }

        .tier-badge {
            display: inline-block;
            padding: 4px 10px;
            border-radius: 12px;
            font-size: 11px;
            font-weight: 600;
        }

        .tier-badge.full {
            background: var(--green-dim);
            color: var(--green);
        }

        .tier-badge.limited {
            background: var(--yellow-dim);
            color: var(--yellow);
        }

        .grade-badge {
            display: inline-block;
            padding: 4px 10px;
            border-radius: 8px;
            font-size: 13px;
            font-weight: 700;
        }

        .grade-badge.good { background: var(--green-dim); color: var(--green); }
        .grade-badge.avg { background: var(--cyan-dim); color: var(--cyan); }
        .grade-badge.poor { background: var(--yellow-dim); color: var(--yellow); }

        .table-btn {
            padding: 8px 14px;
            border: none;
            border-radius: 6px;
            font-size: 12px;
            font-weight: 500;
            cursor: pointer;
            transition: all 0.2s;
        }

        .table-btn.primary {
            background: var(--cyan);
            color: #000;
        }

        .table-btn.primary:hover {
            opacity: 0.9;
        }

        .table-btn.secondary {
            background: var(--bg-main);
            color: var(--text-muted);
            border: 1px solid var(--border-light);
        }

        .table-btn.secondary:hover {
            background: var(--cyan-dim);
            color: var(--cyan);
            border-color: var(--cyan);
        }

        /* Client Cards (Mobile) */
        .clients-cards {
            display: none;
        }

        .client-card {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 12px;
            cursor: pointer;
            transition: all 0.2s;
            border-left: 4px solid var(--cyan);
        }

        .client-card:hover {
            background: rgba(37, 42, 56, 0.8);
        }

        .client-card-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            margin-bottom: 12px;
        }

        .client-card-info {
            display: flex;
            align-items: center;
            gap: 12px;
        }

        .client-card-details h3 {
            font-size: 16px;
            font-weight: 600;
        }

        .client-card-details p {
            font-size: 12px;
            color: var(--text-muted);
        }

        .client-card-stats {
            display: flex;
            gap: 16px;
        }

        .client-card-stat {
            text-align: center;
        }

        .client-card-stat-value {
            font-size: 18px;
            font-weight: 700;
        }

        .client-card-stat-label {
            font-size: 10px;
            color: var(--text-muted);
        }

        .client-card-actions {
            display: flex;
            gap: 8px;
            margin-top: 12px;
            padding-top: 12px;
            border-top: 1px solid var(--border-light);
        }

        /* ============================================
           PRO VIEW - CLIENT DETAIL
           ============================================ */
        .back-link {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            font-size: 13px;
            color: var(--cyan);
            cursor: pointer;
            margin-bottom: 16px;
        }

        .back-link:hover {
            text-decoration: underline;
        }

        .client-detail-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            gap: 20px;
            margin-bottom: 24px;
            flex-wrap: wrap;
        }

        .client-detail-info {
            display: flex;
            align-items: center;
            gap: 16px;
        }

        .client-avatar-lg {
            width: 56px;
            height: 56px;
            border-radius: 50%;
            background: linear-gradient(135deg, var(--cyan), #0099cc);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            font-weight: 700;
        }

        .client-detail-name {
            font-size: 22px;
            font-weight: 700;
        }

        .client-detail-meta {
            font-size: 13px;
            color: var(--text-muted);
            margin-top: 4px;
        }

        .client-detail-stats {
            display: flex;
            gap: 24px;
        }

        .detail-stat {
            text-align: center;
        }

        .detail-stat-value {
            font-size: 24px;
            font-weight: 800;
        }

        .detail-stat-value.grade { color: var(--cyan); }
        .detail-stat-value.green { color: var(--green); }

        .detail-stat-label {
            font-size: 11px;
            color: var(--text-muted);
        }

        /* Tabs */
        .tabs {
            display: flex;
            gap: 0;
            background: var(--bg-card);
            border-radius: 10px;
            padding: 4px;
            margin-bottom: 20px;
            overflow-x: auto;
        }

        .tab {
            flex: 1;
            padding: 12px 16px;
            text-align: center;
            font-size: 13px;
            color: var(--text-muted);
            cursor: pointer;
            border-radius: 8px;
            transition: all 0.2s;
            white-space: nowrap;
            border: none;
            background: transparent;
        }

        .tab:hover {
            color: var(--text-secondary);
        }

        .tab.active {
            background: var(--pro-green-dim);
            color: var(--pro-green);
            font-weight: 600;
        }

        /* Content Cards */
        .content-card {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 20px;
            margin-bottom: 16px;
        }

        .content-card-title {
            font-size: 16px;
            font-weight: 600;
            margin-bottom: 16px;
        }

        /* ============================================
           GRADING OVERVIEW (shared pattern)
           ============================================ */
        .grade-overview {
            display: flex;
            gap: 16px;
            align-items: stretch;
        }

        .overall-grade {
            text-align: center;
            padding: 20px 24px;
            background: var(--cyan-dim);
            border-radius: 12px;
            width: 420px;
            min-width: 420px;
            display: flex;
            flex-direction: column;
        }

        .overall-grade-value {
            font-size: 64px;
            font-weight: 800;
            color: var(--cyan);
            line-height: 1;
        }

        .overall-grade-label {
            font-size: 13px;
            color: var(--text-muted);
            margin-top: 8px;
        }

        .factors-grid {
            flex: 1;
            min-width: 0; /* Prevent grid from overflowing flex parent */
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 6px;
        }

        .factor-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px 12px;
            background: rgba(255,255,255,0.03);
            border-radius: 6px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .factor-item:hover {
            background: rgba(255,255,255,0.06);
        }

        .factor-item.issue {
            background: var(--yellow-dim);
        }

        .factor-name {
            font-size: 13px;
            color: var(--text-secondary);
        }

        .factor-grade {
            font-size: 14px;
            font-weight: 700;
        }

        .factor-grade.a { color: var(--green); }
        .factor-grade.b { color: var(--cyan); }
        .factor-grade.c { color: var(--yellow); }
        .factor-grade.d { color: var(--red); }

        /* Pro-only: Weight display */
        .factor-weight {
            font-size: 10px;
            color: var(--text-dim);
            margin-left: 4px;
        }

        .attention-summary {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 12px 16px;
            background: var(--yellow-dim);
            border: 1px solid rgba(255, 180, 0, 0.3);
            border-radius: 10px;
            margin-top: 16px;
            font-size: 14px;
            color: var(--yellow);
            cursor: pointer;
            transition: all 0.2s ease;
        }
        .attention-summary:hover {
            background: rgba(255, 180, 0, 0.2);
            border-color: rgba(255, 180, 0, 0.5);
        }
        .attention-summary::after {
            content: '→';
            margin-left: auto;
            opacity: 0.6;
        }

        /* Issues Modal Styles */
        .issues-modal-content {
            max-height: 70vh;
            overflow-y: auto;
        }
        .issues-list {
            list-style: none;
            padding: 0;
            margin: 0;
        }
        .issue-item {
            display: flex;
            align-items: flex-start;
            gap: 12px;
            padding: 12px;
            border-bottom: 1px solid var(--border-light);
        }
        .issue-item:last-child {
            border-bottom: none;
        }
        .issue-icon {
            font-size: 16px;
            min-width: 24px;
        }
        .issue-text {
            flex: 1;
            font-size: 14px;
            line-height: 1.5;
        }
        .issue-club-tag {
            font-size: 11px;
            background: var(--cyan-dim);
            color: var(--cyan);
            padding: 2px 8px;
            border-radius: 4px;
            margin-left: auto;
            white-space: nowrap;
        }
        .issue-category {
            font-size: 12px;
            font-weight: 600;
            color: var(--text-muted);
            padding: 8px 12px;
            background: var(--bg-input);
            margin-top: 8px;
        }
        .issue-category:first-child {
            margin-top: 0;
        }

        /* ============================================
           AI BAG SUMMARY
           ============================================ */
        .ai-bag-summary {
            background: var(--bg-card);
            border: 1px solid var(--border-light);
            border-radius: 12px;
            margin-top: 16px;
            overflow: hidden;
        }

        .ai-summary-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 12px 16px;
            background: var(--purple-dim);
            border-bottom: 1px solid var(--border-light);
        }

        .ai-summary-header-left {
            display: flex;
            align-items: center;
            gap: 8px;
            color: var(--purple);
            font-weight: 600;
            font-size: 14px;
        }

        .ai-summary-header .patent-tag {
            font-size: 10px;
            color: var(--text-muted);
            font-weight: 400;
        }

        .ai-summary-body {
            padding: 16px;
        }

        .ai-overall-assessment {
            font-size: 14px;
            line-height: 1.6;
            color: var(--text-primary);
            margin-bottom: 16px;
        }

        .ai-bag-personality {
            font-size: 13px;
            font-style: italic;
            color: var(--text-secondary);
            margin-bottom: 16px;
            padding: 10px 12px;
            background: var(--bg-input);
            border-radius: 8px;
            border-left: 3px solid var(--purple);
        }

        .ai-summary-columns {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 16px;
        }

        @media (max-width: 768px) {
            .ai-summary-columns {
                grid-template-columns: 1fr;
            }
        }

        .ai-summary-section {
            background: var(--bg-input);
            border-radius: 8px;
            padding: 12px;
        }

        .ai-summary-section-title {
            font-size: 12px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin-bottom: 8px;
            display: flex;
            align-items: center;
            gap: 6px;
        }

        .ai-summary-section-title.strengths {
            color: var(--green);
        }

        .ai-summary-section-title.weaknesses {
            color: var(--yellow);
        }

        .ai-summary-section-title.recommendations {
            color: var(--cyan);
        }

        .ai-summary-list {
            list-style: none;
            padding: 0;
            margin: 0;
        }

        .ai-summary-list li {
            font-size: 13px;
            color: var(--text-secondary);
            padding: 4px 0;
            padding-left: 16px;
            position: relative;
        }

        .ai-summary-list li::before {
            content: '•';
            position: absolute;
            left: 0;
            color: var(--text-muted);
        }

        .ai-summary-list.strengths li::before {
            color: var(--green);
        }

        .ai-summary-list.weaknesses li::before {
            color: var(--yellow);
        }

        .ai-summary-list.recommendations li::before {
            content: '→';
            color: var(--cyan);
        }

        .ai-recommendations-section {
            margin-top: 16px;
            padding-top: 16px;
            border-top: 1px solid var(--border-light);
        }

        .ai-summary-empty {
            text-align: center;
            padding: 24px;
            color: var(--text-muted);
            font-size: 13px;
        }

        .ai-summary-disclaimer {
            margin-top: 16px;
            padding-top: 12px;
            border-top: 1px solid var(--border-light);
            font-size: 10px;
            color: var(--text-dim);
            line-height: 1.5;
            font-style: italic;
        }

        /* ============================================
           CLUB CARDS (status-based, no letter grades)
           ============================================ */
        .clubs-section {
            margin-top: 20px;
        }

        .section-label {
            font-size: 12px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 12px;
            margin-top: 20px;
        }

        .section-label:first-child {
            margin-top: 0;
        }

        .club-card {
            background: var(--bg-card);
            border-radius: 10px;
            padding: 14px;
            margin-bottom: 10px;
            border-left: 4px solid var(--cyan);
            position: relative;
        }

        .club-card.status-good { border-left-color: var(--green); }
        .club-card.status-attention { border-left-color: var(--yellow); }
        .club-card.status-problem { border-left-color: var(--red); }

        .club-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 6px;
        }

        .club-header-left {
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .club-name {
            font-size: 15px;
            font-weight: 600;
        }

        .club-status {
            font-size: 11px;
            font-weight: 600;
            padding: 3px 8px;
            border-radius: 10px;
        }

        .club-status.good {
            background: var(--green-dim);
            color: var(--green);
        }

        .club-status.attention {
            background: var(--yellow-dim);
            color: var(--yellow);
        }

        .club-status.problem {
            background: var(--red-dim);
            color: var(--red);
        }

        .club-menu-btn {
            background: none;
            border: none;
            color: var(--text-muted);
            font-size: 18px;
            cursor: pointer;
            padding: 4px 8px;
            border-radius: 4px;
        }

        .club-menu-btn:hover {
            background: rgba(255,255,255,0.1);
            color: var(--text-primary);
        }

        .club-menu-wrapper {
            position: relative;
        }

        .club-menu-dropdown {
            display: none;
            position: absolute;
            top: 100%;
            right: 0;
            background: var(--bg-card);
            border: 1px solid var(--border-medium);
            border-radius: 8px;
            box-shadow: 0 4px 12px rgba(0,0,0,0.3);
            z-index: 100;
            min-width: 120px;
            overflow: hidden;
        }

        .club-menu-dropdown.show {
            display: block;
        }

        .club-menu-item {
            display: block;
            width: 100%;
            padding: 10px 14px;
            background: none;
            border: none;
            text-align: left;
            font-size: 13px;
            color: var(--text-primary);
            cursor: pointer;
            transition: background 0.15s;
        }

        .club-menu-item:hover {
            background: var(--cyan-dim);
            color: var(--cyan);
        }

        .club-menu-item.danger:hover {
            background: var(--red-dim);
            color: var(--red);
        }

        .club-specs {
            font-size: 13px;
            color: var(--text-secondary);
            line-height: 1.5;
        }

        .club-issue {
            font-size: 12px;
            color: var(--yellow);
            margin-top: 8px;
            padding: 8px 10px;
            background: var(--yellow-dim);
            border-radius: 6px;
        }

        .club-suggestion {
            font-size: 12px;
            color: var(--purple);
            margin-top: 6px;
            padding: 8px 10px;
            background: var(--purple-dim);
            border-radius: 6px;
        }

        .club-actions {
            display: flex;
            gap: 8px;
            margin-top: 12px;
        }

        .club-action-btn {
            flex: 1;
            padding: 10px;
            border: none;
            border-radius: 8px;
            font-size: 12px;
            font-weight: 500;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 6px;
            transition: all 0.2s;
        }

        .club-action-btn.scenario {
            background: var(--cyan-dim);
            color: var(--cyan);
        }

        .club-action-btn.scenario:hover {
            background: rgba(0, 212, 255, 0.25);
        }

        .club-action-btn.test {
            background: var(--purple-dim);
            color: var(--purple);
        }

        .club-action-btn.test:hover {
            background: rgba(168, 85, 247, 0.25);
        }

        /* Pro-only: Shop button */
        .club-action-btn.shop {
            background: var(--green-dim);
            color: var(--green);
        }

        .club-action-btn.shop:hover {
            background: rgba(0, 200, 100, 0.25);
        }

        /* Club Rating Stars */
        .club-rating-row {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-top: 8px;
            padding-top: 8px;
            border-top: 1px solid var(--border-light);
        }
        .club-rating-label {
            font-size: 11px;
            color: #AAAABB;
            white-space: nowrap;
        }
        .club-rating-stars {
            display: flex;
            gap: 2px;
        }
        .club-rating-star {
            font-size: 18px;
            cursor: pointer;
            color: #666677;
            transition: color 0.15s;
            background: none;
            border: none;
            padding: 0;
            line-height: 1;
        }
        .club-rating-star.filled {
            color: #FFD600;
        }
        .club-rating-star:hover,
        .club-rating-star.hover {
            color: #FFD600;
        }
        .club-rating-edit {
            font-size: 10px;
            color: var(--cyan);
            cursor: pointer;
            margin-left: 4px;
        }
        .club-rating-pro-badge {
            font-size: 9px;
            background: var(--cyan-dim);
            color: var(--cyan);
            padding: 1px 5px;
            border-radius: 4px;
            font-weight: 600;
            margin-left: 4px;
        }

        /* Add Club Button */
        .add-club-btn {
            width: 100%;
            padding: 14px;
            background: transparent;
            border: 2px dashed var(--border-medium);
            border-radius: 10px;
            color: var(--text-muted);
            font-size: 14px;
            cursor: pointer;
            margin-top: 12px;
            transition: all 0.2s;
        }

        .add-club-btn:hover {
            border-color: var(--cyan);
            color: var(--cyan);
        }

        /* ============================================
           CLIENT PREVIEW (Phone Frame)
           ============================================ */
        .phone-frame-container {
            display: flex;
            justify-content: center;
            padding: 20px;
        }

        .phone-frame {
            width: 375px;
            max-width: 100%;
            background: var(--bg-main);
            border-radius: 40px;
            padding: 20px;
            box-shadow: 0 25px 80px rgba(0,0,0,0.5);
            border: 3px solid #333;
        }

        .phone-screen {
            background: var(--bg-main);
            border-radius: 25px;
            min-height: 700px;
            overflow: hidden;
        }

        .phone-header {
            background: var(--bg-dark);
            padding: 16px 20px;
            display: flex;
            align-items: center;
            justify-content: space-between;
        }

        .phone-header-left {
            display: flex;
            align-items: center;
            gap: 12px;
        }

        .phone-back-btn {
            color: var(--cyan);
            font-size: 20px;
            background: none;
            border: none;
            cursor: pointer;
        }

        .phone-title {
            font-size: 16px;
            font-weight: 600;
        }

        .phone-credits {
            font-size: 11px;
            color: var(--cyan);
            background: var(--cyan-dim);
            padding: 4px 10px;
            border-radius: 12px;
        }

        .phone-content {
            padding: 16px;
        }

        /* ============================================
           BUTTONS (shared)
           ============================================ */
        .btn {
            padding: 12px 20px;
            border-radius: 10px;
            font-size: 14px;
            font-weight: 600;
            border: none;
            cursor: pointer;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            transition: all 0.2s;
        }

        .btn:hover { opacity: 0.9; }

        .btn-primary {
            background: linear-gradient(135deg, var(--cyan), #0099cc);
            color: #000;
        }

        .btn-secondary {
            background: rgba(255,255,255,0.1);
            color: var(--text-primary);
        }

        .btn-pro {
            background: linear-gradient(135deg, var(--pro-green), #2e7d32);
            color: #fff;
        }

        .btn-sm {
            padding: 8px 14px;
            font-size: 12px;
        }

        /* ============================================
           RESPONSIVE STYLES
           ============================================ */
        @media (max-width: 768px) {
            .app-container {
                padding: 12px;
            }

            .main-header {
                padding: 10px 12px;
            }

            .header-content {
                flex-wrap: wrap;
                gap: 12px;
            }

            .header-left {
                width: 100%;
                justify-content: space-between;
            }

            .view-toggle {
                order: 3;
                width: 100%;
            }

            .view-toggle-btn {
                flex: 1;
                padding: 10px;
            }

            .header-right {
                width: 100%;
                justify-content: flex-end;
                gap: 12px;
            }

            .credits-label {
                display: none;
            }

            /* Stats */
            .stats-grid {
                grid-template-columns: repeat(2, 1fr);
            }

            .stat-value {
                font-size: 22px;
            }

            /* Table → Cards */
            .clients-table {
                display: none;
            }

            .clients-cards {
                display: block;
            }

            /* Client Detail */
            .client-detail-header {
                flex-direction: column;
            }

            .client-detail-stats {
                width: 100%;
                justify-content: space-around;
            }

            .tabs {
                overflow-x: auto;
                -webkit-overflow-scrolling: touch;
            }

            .tab {
                padding: 10px 12px;
                font-size: 12px;
            }

            /* Content card — reduce padding on mobile for more room */
            .content-card {
                padding: 12px;
                max-width: 100%;
                box-sizing: border-box;
            }

            /* Grade Overview — stack vertically, prevent factor card clipping */
            .grade-overview {
                flex-direction: column;
                max-width: 100%;
                gap: 8px;
            }

            .overall-grade {
                width: 100% !important;
                min-width: unset !important;
                max-width: 100%;
                padding: 16px;
            }

            .overall-grade-value {
                font-size: 48px;
            }

            .factors-grid {
                grid-template-columns: repeat(2, 1fr);
                gap: 4px;
                width: 100%;
            }

            .factor-item {
                min-width: 0;
                padding: 8px 8px;
            }

            .factor-name {
                font-size: 12px;
                overflow: hidden;
                text-overflow: ellipsis;
                white-space: nowrap;
            }

            .factor-grade {
                font-size: 13px;
                flex-shrink: 0;
            }

            .factor-weight {
                display: none; /* Hide weight labels on mobile to save space */
            }

            /* Scenario results — factor change rows */
            .factor-changes {
                padding: 10px;
                overflow-x: auto;
            }

            .factor-change-row {
                padding: 8px 0;
            }

            .factor-change-name {
                font-size: 12px;
                min-width: 0;
                overflow: hidden;
                text-overflow: ellipsis;
                white-space: nowrap;
                flex: 1;
            }

            .factor-change-value {
                font-size: 12px;
                flex-shrink: 0;
                text-align: right;
            }

            /* Result grade comparison — fit on small screens */
            .result-grade-comparison {
                gap: 16px;
            }

            .result-grade-value {
                font-size: 36px;
            }

            .result-arrow {
                font-size: 24px;
            }

            /* Club action buttons — wrap on mobile so all buttons are reachable */
            .club-actions {
                flex-wrap: wrap;
            }

            .club-action-btn {
                flex: 0 0 auto;
                padding: 8px 10px;
                font-size: 11px;
            }

            /* Scenario builder — stack grid on mobile so issues panel isn't clipped */
            #scenario-grid {
                grid-template-columns: 1fr !important;
            }
            #scenario-issues-panel {
                max-width: 100%;
                box-sizing: border-box;
            }

            /* Club card — reduce padding on mobile */
            .club-card {
                padding: 10px;
            }

            .club-name {
                font-size: 13px;
            }

            .club-specs {
                font-size: 12px;
            }

            /* Phone Frame on Mobile - remove frame */
            .phone-frame-container {
                padding: 0;
            }

            .phone-frame {
                border-radius: 0;
                padding: 0;
                border: none;
                box-shadow: none;
                width: 100%;
            }

            .phone-screen {
                border-radius: 0;
                min-height: auto;
            }

            /* Demo Controls */
            .demo-controls {
                flex-direction: column;
                align-items: flex-start;
            }

        }

        /* Hide elements based on view — start hidden to prevent flash before auth */
        .pro-only { display: none; }
        .client-only { display: none; }
        .client-only-inline { display: none; }
        .pro-only-inline { display: none; }
        .pro-only-flex { display: none; }

        body.pro-view .pro-only { display: block; }
        body.pro-view .pro-only-flex { display: flex; }
        body.pro-view .pro-only-inline { display: inline; }
        body.pro-view .client-detail-header.pro-only { display: flex; }

        body.client-view .client-only { display: block; }
        body.client-view .client-only-inline { display: inline; }
        body.client-view .client-detail-header.client-only { display: flex; }
        /* ============================================
           SCENARIO BUILDER
           ============================================ */
        .scenario-container {
            max-width: 500px;
            margin: 0 auto;
        }

        .scenario-header {
            text-align: center;
            margin-bottom: 24px;
        }

        .scenario-title {
            font-size: 20px;
            font-weight: 700;
            margin-bottom: 8px;
        }

        .scenario-subtitle {
            font-size: 14px;
            color: var(--text-muted);
        }

        .scenario-progress {
            display: flex;
            justify-content: center;
            gap: 8px;
            margin-bottom: 24px;
        }

        .progress-step {
            width: 40px;
            height: 4px;
            background: var(--border-medium);
            border-radius: 2px;
            transition: background 0.3s;
        }

        .progress-step.active {
            background: var(--cyan);
        }

        .progress-step.complete {
            background: var(--green);
        }

        .scenario-step {
            display: none;
        }

        .scenario-step.active {
            display: block;
        }

        /* Club Selection Grid */
        .club-select-grid {
            display: grid;
            gap: 10px;
        }

        .club-select-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 14px;
            background: var(--bg-card);
            border: 2px solid var(--border-medium);
            border-radius: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .club-select-item:hover {
            border-color: var(--cyan);
        }

        .club-select-item.selected {
            border-color: var(--cyan);
            background: var(--cyan-dim);
        }

        .club-select-icon {
            width: 40px;
            height: 40px;
            background: var(--bg-main);
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
        }

        .club-select-info {
            flex: 1;
        }

        .club-select-name {
            font-weight: 600;
            font-size: 15px;
        }

        .club-select-specs {
            font-size: 12px;
            color: var(--text-muted);
            margin-top: 2px;
        }

        .club-select-status {
            font-size: 11px;
            padding: 3px 8px;
            border-radius: 10px;
        }

        .club-select-status.good {
            background: var(--green-dim);
            color: var(--green);
        }

        .club-select-status.attention {
            background: var(--yellow-dim);
            color: var(--yellow);
        }

        /* Category Selection */
        .category-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 12px;
        }

        .category-card {
            padding: 20px;
            background: var(--bg-card);
            border: 2px solid var(--border-medium);
            border-radius: 12px;
            text-align: center;
            cursor: pointer;
            transition: all 0.2s;
        }

        .category-card:hover {
            border-color: var(--cyan);
        }

        .category-card.selected {
            border-color: var(--cyan);
            background: var(--cyan-dim);
        }

        .category-icon {
            font-size: 32px;
            margin-bottom: 8px;
        }

        .category-name {
            font-weight: 600;
            font-size: 14px;
        }

        /* Club Browser */
        .club-browser {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 16px;
        }

        .browser-section {
            margin-bottom: 16px;
        }

        .browser-label {
            font-size: 12px;
            color: var(--text-muted);
            margin-bottom: 8px;
            display: block;
        }

        .browser-select {
            width: 100%;
            padding: 12px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 14px;
        }

        .suggested-clubs {
            margin-top: 16px;
        }

        .suggested-label {
            font-size: 12px;
            color: var(--text-muted);
            margin-bottom: 12px;
            display: flex;
            align-items: center;
            gap: 6px;
        }

        .suggested-card {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px;
            background: var(--bg-main);
            border: 2px solid var(--border-medium);
            border-radius: 10px;
            cursor: pointer;
            margin-bottom: 10px;
            transition: all 0.2s;
        }

        .suggested-card:hover {
            border-color: var(--purple);
        }

        .suggested-card.selected {
            border-color: var(--purple);
            background: var(--purple-dim);
        }

        .suggested-badge {
            background: var(--purple);
            color: #000;
            font-size: 9px;
            font-weight: 700;
            padding: 3px 6px;
            border-radius: 4px;
        }

        /* Comparison View */
        .comparison-container {
            display: grid;
            grid-template-columns: 1fr auto 1fr;
            gap: 16px;
            align-items: stretch;
        }

        .comparison-card {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 16px;
            text-align: center;
        }

        .comparison-card.current {
            border: 2px solid var(--border-medium);
        }

        .comparison-card.new {
            border: 2px solid var(--cyan);
        }

        .comparison-label {
            font-size: 11px;
            color: var(--text-muted);
            text-transform: uppercase;
            margin-bottom: 12px;
        }

        .comparison-club-name {
            font-size: 16px;
            font-weight: 700;
            margin-bottom: 4px;
        }

        .comparison-specs {
            font-size: 12px;
            color: var(--text-secondary);
            line-height: 1.5;
        }

        .comparison-arrow {
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 24px;
            color: var(--cyan);
        }

        /* Scenario Results */
        .result-grade-comparison {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 24px;
            margin-bottom: 24px;
        }

        .result-grade {
            text-align: center;
        }

        .result-grade-value {
            font-size: 48px;
            font-weight: 800;
            line-height: 1;
        }

        .result-grade-value.current {
            color: var(--text-muted);
        }

        .result-grade-value.new {
            color: var(--green);
        }

        .result-grade-label {
            font-size: 12px;
            color: var(--text-muted);
            margin-top: 8px;
        }

        .result-arrow {
            font-size: 32px;
            color: var(--green);
        }

        .result-improvement {
            text-align: center;
            padding: 12px;
            background: var(--green-dim);
            border-radius: 10px;
            margin-bottom: 20px;
        }

        .result-improvement-text {
            font-size: 16px;
            font-weight: 600;
            color: var(--green);
        }

        .factor-changes {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 20px;
        }

        .factor-change-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px 0;
            border-bottom: 1px solid var(--border-light);
        }

        .factor-change-row:last-child {
            border-bottom: none;
        }

        .factor-change-name {
            font-size: 14px;
        }

        .factor-change-value {
            font-size: 14px;
            font-weight: 600;
        }

        .factor-change-value.improved {
            color: var(--green);
        }

        .factor-change-value.same {
            color: var(--text-muted);
        }

        .factor-change-value.declined {
            color: var(--red);
        }

        .ai-explanation {
            background: var(--purple-dim);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 20px;
        }

        .ai-explanation-header {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 10px;
            font-weight: 600;
            color: var(--purple);
        }

        .ai-explanation-text {
            font-size: 14px;
            color: var(--text-secondary);
            line-height: 1.6;
        }

        .scenario-actions {
            display: grid;
            gap: 10px;
        }

        .scenario-action-btn {
            width: 100%;
            padding: 14px;
            border-radius: 10px;
            font-size: 14px;
            font-weight: 600;
            border: none;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            transition: all 0.2s;
            background: var(--bg-card);
            color: var(--text-muted);
        }

        .scenario-action-btn:hover {
            background: var(--pro-green-dim);
            color: var(--pro-green);
        }

        .scenario-action-btn:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }

        /* Saved Scenario Cards */
        .saved-scenario-card {
            background: var(--bg-main);
            border: 1px solid var(--border-light);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .saved-scenario-card:hover {
            border-color: var(--cyan);
            background: var(--bg-card);
        }

        .scenario-nav {
            display: flex;
            gap: 12px;
            margin-top: 24px;
        }

        .scenario-nav .btn {
            flex: 1;
        }

        /* Credit cost indicator */
        .credit-cost {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            font-size: 11px;
            color: var(--cyan);
            background: var(--cyan-dim);
            padding: 2px 8px;
            border-radius: 10px;
            margin-left: 8px;
        }

        /* Retail-style Scenario Components */
        .scenario-card {
            background: var(--bg-card);
            border-radius: 10px;
            padding: 14px;
            margin-bottom: 12px;
        }

        .scenario-label {
            font-size: 11px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin-bottom: 8px;
        }

        .scenario-current {
            font-size: 13px;
            color: var(--text-secondary);
            padding: 10px;
            background: var(--bg-main);
            border-radius: 6px;
            line-height: 1.5;
        }

        .scenario-swap {
            font-size: 13px;
            color: var(--cyan);
            padding: 12px;
            background: var(--cyan-dim);
            border: 1px dashed var(--cyan);
            border-radius: 6px;
            cursor: pointer;
            text-align: center;
            transition: all 0.2s;
        }

        .scenario-swap:hover {
            background: rgba(0, 212, 255, 0.15);
        }

        .scenario-swap.filled {
            background: rgba(0, 200, 100, 0.1);
            border-color: var(--green);
            color: var(--green);
        }

        /* Dropdown (Retail style) */
        .dropdown {
            background: var(--bg-card);
            border: 2px solid var(--border-medium);
            border-radius: 10px;
            margin-bottom: 12px;
            cursor: pointer;
            transition: all 0.2s;
            position: relative;
        }

        .dropdown:hover {
            border-color: var(--border-light);
        }

        .dropdown.filled {
            border-color: var(--cyan);
        }

        .dropdown.open {
            overflow: visible;
        }

        .dropdown-header {
            padding: 14px 16px;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .dropdown-value {
            font-size: 15px;
            color: var(--text-primary);
        }

        .dropdown-value.placeholder {
            color: var(--text-dim);
        }

        .dropdown-arrow {
            color: var(--text-dim);
            font-size: 12px;
            transition: transform 0.2s;
        }

        .dropdown.open .dropdown-arrow {
            transform: rotate(180deg);
        }

        .dropdown-options {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.3s;
            background: var(--bg-main);
            border-top: 1px solid var(--border-medium);
        }

        .dropdown.open .dropdown-options {
            max-height: 280px;
            overflow-y: auto;
        }

        .dropdown-option {
            padding: 12px 16px;
            font-size: 14px;
            cursor: pointer;
            transition: background 0.2s;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .dropdown-option:hover {
            background: rgba(255, 255, 255, 0.05);
        }

        .dropdown-option .status-badge {
            font-size: 11px;
        }

        .dropdown-option .status-badge.attention {
            color: var(--yellow);
        }

        .dropdown-option .status-badge.good {
            color: var(--green);
        }

        /* Yes/No Buttons */
        .yes-no-row {
            display: flex;
            gap: 12px;
        }

        .yes-no-btn {
            flex: 1;
            padding: 14px;
            border-radius: 10px;
            text-align: center;
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            border: 2px solid var(--border-medium);
            background: transparent;
            color: var(--text-muted);
            transition: all 0.2s;
        }

        .yes-no-btn:hover {
            border-color: var(--border-light);
            color: var(--text-secondary);
        }

        .yes-no-btn.selected-yes {
            background: rgba(0, 200, 100, 0.15);
            border-color: var(--green);
            color: var(--green);
        }

        .yes-no-btn.selected-no {
            background: rgba(0, 212, 255, 0.15);
            border-color: var(--cyan);
            color: var(--cyan);
        }

        /* Head/Shaft Picker Screens */
        .picker-screen {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: var(--bg-dark);
            z-index: 500;
            overflow-y: auto;
        }

        .picker-screen.active {
            display: block;
        }

        .picker-header {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 16px 20px;
            background: var(--bg-main);
            border-bottom: 1px solid var(--border-light);
            position: sticky;
            top: 0;
            z-index: 10;
        }

        .picker-back {
            background: none;
            border: none;
            color: var(--cyan);
            font-size: 20px;
            cursor: pointer;
            padding: 4px;
        }

        .picker-title {
            font-size: 17px;
            font-weight: 600;
        }

        .picker-content {
            padding: 20px;
        }

        .picker-filters {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin-bottom: 16px;
        }

        .picker-filter {
            padding: 8px 14px;
            background: var(--bg-card);
            border: 1px solid var(--border-medium);
            border-radius: 20px;
            color: var(--text-muted);
            font-size: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .picker-filter:hover {
            border-color: var(--cyan);
            color: var(--cyan);
        }

        .picker-filter.active {
            background: var(--cyan-dim);
            border-color: var(--cyan);
            color: var(--cyan);
        }

        .picker-card {
            background: var(--bg-card);
            border: 2px solid var(--border-medium);
            border-radius: 12px;
            padding: 14px;
            margin-bottom: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .picker-card:hover {
            border-color: var(--border-light);
        }

        .picker-card.selected {
            border-color: var(--cyan);
            background: var(--cyan-dim);
        }

        .picker-card-name {
            font-size: 15px;
            font-weight: 600;
            margin-bottom: 4px;
        }

        .picker-card-specs {
            font-size: 12px;
            color: var(--text-muted);
            line-height: 1.4;
        }

        .picker-card-badge {
            display: inline-block;
            font-size: 10px;
            background: var(--green-dim);
            color: var(--green);
            padding: 2px 8px;
            border-radius: 10px;
            margin-bottom: 6px;
        }

        /* Scenario Ready Review */
        .review-section {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 16px;
        }

        .review-label {
            font-size: 11px;
            color: var(--text-muted);
            text-transform: uppercase;
            margin-bottom: 8px;
        }

        .review-content {
            font-size: 14px;
            color: var(--text-secondary);
            line-height: 1.5;
        }

        /* ============================================
           PERFORMANCE TESTING
           ============================================ */
        .perf-test-container {
            max-width: 500px;
            margin: 0 auto;
        }

        .perf-test-header {
            text-align: center;
            margin-bottom: 24px;
        }

        .perf-test-title {
            font-size: 20px;
            font-weight: 700;
            margin-bottom: 8px;
        }

        .perf-test-subtitle {
            font-size: 14px;
            color: var(--text-muted);
        }

        /* Club Selector for Test */
        .test-club-selector {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 20px;
        }

        .test-club-current {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px;
            background: var(--cyan-dim);
            border-radius: 10px;
            margin-bottom: 12px;
        }

        .test-club-icon {
            width: 44px;
            height: 44px;
            background: var(--bg-main);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
        }

        .test-club-info h3 {
            font-size: 16px;
            font-weight: 600;
        }

        .test-club-info p {
            font-size: 12px;
            color: var(--text-muted);
            margin-top: 2px;
        }

        .change-club-btn {
            width: 100%;
            padding: 10px;
            background: rgba(255,255,255,0.05);
            border: 1px dashed var(--border-medium);
            border-radius: 8px;
            color: var(--text-muted);
            font-size: 13px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .change-club-btn:hover {
            border-color: var(--cyan);
            color: var(--cyan);
        }

        /* Data Entry Form */
        .perf-data-form {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 20px;
            margin-bottom: 20px;
        }

        .form-section-title {
            font-size: 14px;
            font-weight: 600;
            margin-bottom: 16px;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .perf-input-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 12px;
        }

        .perf-input-group {
            display: flex;
            flex-direction: column;
        }

        .perf-input-group.full-width {
            grid-column: span 2;
        }

        .perf-input-label {
            font-size: 12px;
            color: var(--text-muted);
            margin-bottom: 6px;
        }

        .perf-input {
            padding: 12px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 16px;
            text-align: center;
            transition: border-color 0.2s;
        }

        .perf-input:focus {
            outline: none;
            border-color: var(--cyan);
        }

        .perf-input::placeholder {
            color: var(--text-dim);
        }

        .input-unit {
            font-size: 12px;
            color: var(--text-dim);
            text-align: center;
            margin-top: 4px;
        }

        /* Goals Selection */
        .goals-section {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 20px;
            margin-bottom: 20px;
        }

        .goal-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
        }

        .goal-chip {
            padding: 10px 16px;
            background: var(--bg-main);
            border: 2px solid var(--border-medium);
            border-radius: 20px;
            font-size: 13px;
            color: var(--text-secondary);
            cursor: pointer;
            transition: all 0.2s;
        }

        .goal-chip:hover {
            border-color: var(--purple);
        }

        .goal-chip.selected {
            border-color: var(--purple);
            background: var(--purple-dim);
            color: var(--purple);
        }

        /* Test Results */
        .test-results {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 20px;
            margin-bottom: 20px;
        }

        .test-result-summary {
            text-align: center;
            padding: 20px;
            background: var(--cyan-dim);
            border-radius: 12px;
            margin-bottom: 20px;
        }

        .test-result-icon {
            font-size: 48px;
            margin-bottom: 12px;
        }

        .test-result-title {
            font-size: 18px;
            font-weight: 700;
            margin-bottom: 4px;
        }

        .test-result-subtitle {
            font-size: 13px;
            color: var(--text-muted);
        }

        .test-metrics-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 12px;
            margin-bottom: 20px;
        }

        .test-metric {
            text-align: center;
            padding: 14px;
            background: var(--bg-main);
            border-radius: 10px;
        }

        .test-metric-value {
            font-size: 22px;
            font-weight: 800;
            color: var(--cyan);
        }

        .test-metric-value.good { color: var(--green); }
        .test-metric-value.warning { color: var(--yellow); }

        .test-metric-label {
            font-size: 11px;
            color: var(--text-muted);
            margin-top: 4px;
        }

        .test-metric-compare {
            font-size: 10px;
            color: var(--green);
            margin-top: 4px;
        }

        .test-metric-compare.down {
            color: var(--red);
        }

        /* AI Analysis */
        .test-ai-analysis {
            background: var(--purple-dim);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 20px;
        }

        .test-ai-header {
            display: flex;
            align-items: center;
            gap: 8px;
            font-weight: 600;
            color: var(--purple);
            margin-bottom: 10px;
        }

        .test-ai-text {
            font-size: 14px;
            color: var(--text-secondary);
            line-height: 1.6;
        }

        /* Test History */
        .test-history {
            background: var(--bg-card);
            border-radius: 12px;
            padding: 20px;
        }

        .history-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 16px;
        }

        .history-title {
            font-size: 14px;
            font-weight: 600;
        }

        .history-filter {
            font-size: 12px;
            color: var(--cyan);
            cursor: pointer;
        }

        .history-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 12px;
            background: var(--bg-main);
            border-radius: 8px;
            margin-bottom: 8px;
        }

        .history-item:last-child {
            margin-bottom: 0;
        }

        .history-date {
            font-size: 12px;
            color: var(--text-muted);
        }

        .history-club {
            font-size: 14px;
            font-weight: 500;
        }

        .history-stats {
            display: flex;
            gap: 16px;
        }

        .history-stat {
            text-align: right;
        }

        .history-stat-value {
            font-size: 14px;
            font-weight: 600;
            color: var(--cyan);
        }

        .history-stat-label {
            font-size: 10px;
            color: var(--text-dim);
        }

        .perf-test-actions {
            display: grid;
            gap: 10px;
        }

        /* Photo Capture (from Retail) */
        .photo-capture-area {
            background: var(--bg-card);
            border: 2px dashed var(--border-medium);
            border-radius: 12px;
            padding: 30px;
            text-align: center;
            cursor: pointer;
            transition: all 0.2s;
            margin-bottom: 16px;
        }

        .photo-capture-area:hover {
            border-color: var(--cyan);
            background: rgba(0, 212, 255, 0.05);
        }

        .photo-capture-icon {
            font-size: 40px;
            margin-bottom: 10px;
        }

        .photo-capture-text {
            font-size: 14px;
            color: var(--text-secondary);
            margin-bottom: 4px;
        }

        .photo-capture-hint {
            font-size: 11px;
            color: var(--text-dim);
        }

        .photo-thumbnails {
            display: flex;
            gap: 10px;
            flex-wrap: wrap;
            margin-bottom: 16px;
        }

        .photo-thumb {
            width: 60px;
            height: 60px;
            background: var(--bg-main);
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            font-size: 24px;
        }

        .photo-thumb button {
            position: absolute;
            top: -6px;
            right: -6px;
            width: 18px;
            height: 18px;
            border-radius: 50%;
            background: var(--red);
            border: none;
            color: #fff;
            font-size: 11px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .btn-skip {
            width: 100%;
            padding: 12px;
            background: transparent;
            border: none;
            color: var(--text-muted);
            font-size: 14px;
            cursor: pointer;
            margin-top: 10px;
        }

        .btn-skip:hover {
            color: var(--cyan);
        }

        /* Processing Overlay */
        .processing-overlay {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(13, 15, 20, 0.95);
            display: none;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            z-index: 2000;
        }

        .processing-overlay.active {
            display: flex;
        }

        .processing-icon {
            font-size: 50px;
            margin-bottom: 16px;
            animation: pulse 1.5s infinite;
        }

        @keyframes pulse {
            0%, 100% { opacity: 1; transform: scale(1); }
            50% { opacity: 0.7; transform: scale(1.1); }
        }

        .processing-text {
            font-size: 18px;
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: 8px;
        }

        .processing-sub {
            font-size: 13px;
            color: var(--text-muted);
        }

        /* Data Input (retail style) */
        .data-input-group {
            margin-bottom: 14px;
        }

        .data-input-label {
            font-size: 11px;
            color: var(--text-muted);
            margin-bottom: 6px;
            display: flex;
            justify-content: space-between;
        }

        .data-input {
            width: 100%;
            padding: 12px 14px;
            background: var(--bg-card);
            border: 2px solid var(--border-medium);
            border-radius: 10px;
            color: var(--text-primary);
            font-size: 16px;
            transition: all 0.2s;
        }

        .data-input:focus {
            outline: none;
            border-color: var(--cyan);
        }

        .data-input::placeholder {
            color: var(--text-dim);
        }

        .unit-hint {
            color: var(--text-dim);
        }

        /* ============================================
           AI OPPORTUNITIES V2
           ============================================ */

        /* ── V2 Topbar ── */
        .v2-topbar {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 16px;
            padding: 10px 0 20px;
            flex-wrap: wrap;
        }
        .v2-pageTitle {
            font-size: 17px;
            font-weight: 800;
            line-height: 1.15;
            margin-bottom: 0;
        }
        .v2-sub {
            font-size: 12px;
            color: var(--text-muted);
            margin-top: 1px;
        }
        .v2-topActions {
            display: flex;
            align-items: center;
            gap: 10px;
            flex-wrap: wrap;
            justify-content: flex-end;
        }
        .v2-pill {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 8px 12px;
            border: 1px solid var(--border-light);
            background: rgba(17,24,42,.5);
            border-radius: 999px;
            color: var(--text-muted);
            font-size: 12px;
            font-weight: 600;
        }

        /* ── V2 Buttons ── */
        .v2-btn {
            cursor: pointer;
            border: 1px solid var(--border-light);
            background: linear-gradient(180deg, rgba(35,50,88,.75), rgba(26,36,64,.75));
            color: var(--text-primary);
            padding: 9px 14px;
            border-radius: 999px;
            font-weight: 700;
            font-size: 12.5px;
            display: inline-flex;
            align-items: center;
            gap: 7px;
            transition: transform .05s ease, background .15s ease, border-color .15s ease;
            user-select: none;
            white-space: nowrap;
            font-family: inherit;
        }
        .v2-btn:hover { background: linear-gradient(180deg, rgba(43,62,110,.85), rgba(26,36,64,.85)); border-color: #2b3a60; }
        .v2-btn:active { transform: translateY(1px); }
        .v2-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(96,165,250,.35); }
        .v2-btn-primary {
            border-color: rgba(45,212,191,.30);
            background: linear-gradient(180deg, rgba(45,212,191,.15), rgba(26,36,64,.80));
        }
        .v2-btn-primary:hover { border-color: rgba(45,212,191,.50); background: linear-gradient(180deg, rgba(45,212,191,.22), rgba(26,36,64,.85)); }
        .v2-btn-message {
            border-color: rgba(45,212,191,.35);
            background: linear-gradient(180deg, rgba(45,212,191,.18), rgba(26,36,64,.80));
            color: var(--green);
        }
        .v2-btn-message:hover { border-color: rgba(45,212,191,.55); }
        .v2-btn-proposal { border-color: rgba(96,165,250,.25); }
        .v2-btn-proposal:hover { border-color: rgba(96,165,250,.45); }
        .v2-btn-ghost { background: rgba(17,24,42,.4); }
        .v2-btn-danger { border-color: rgba(251,113,133,.25); color: var(--red, #fb7185); }
        .v2-btn-sm { padding: 7px 10px; font-size: 11.5px; }

        /* ── V2 KPI Strip ── */
        .v2-kpiCard {
            background: linear-gradient(180deg, rgba(17,24,42,.82), rgba(15,22,38,.80));
            border: 1px solid var(--border-light);
            border-radius: 18px;
            box-shadow: 0 10px 30px rgba(0,0,0,.35);
            padding: 16px;
            margin-bottom: 4px;
        }
        .v2-kpiHeader {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 14px;
        }
        .v2-kpiHeader h2 {
            font-size: 13px;
            font-weight: 800;
            letter-spacing: .3px;
            text-transform: uppercase;
            color: var(--text-muted);
            margin: 0;
        }
        .v2-kpis {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 10px;
        }
        @media (max-width: 960px) {
            .v2-kpis { grid-template-columns: repeat(2, 1fr); }
            .v2-top3 { grid-template-columns: 1fr; }
        }
        .v2-kpi {
            padding: 14px;
            border-radius: 14px;
            border: 1px solid rgba(31,42,68,.85);
            background: rgba(15,22,38,.5);
            cursor: pointer;
            transition: transform .06s ease, border-color .15s ease;
        }
        .v2-kpi:hover { transform: translateY(-1px); border-color: #2a3a64; }
        .v2-kpi-label { font-size: 11.5px; color: var(--text-muted); font-weight: 600; }
        .v2-kpi-value { font-size: 22px; font-weight: 900; margin-top: 4px; letter-spacing: -.3px; }
        .v2-kpi-hint { font-size: 11px; color: var(--text-muted); margin-top: 4px; font-weight: 500; }

        /* ── V2 Section Titles ── */
        .v2-sectionHead {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            margin: 18px 2px 8px;
        }
        .v2-sectionHead h3 { font-size: 14px; font-weight: 800; margin: 0; }
        .v2-meta { font-size: 12px; color: var(--text-muted); font-weight: 600; }

        /* ── V2 Top 3 Cards ── */
        .v2-top3 {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 12px;
        }

        .v2-heroCard {
            border-radius: 18px;
            border: 1px solid rgba(31,42,68,.85);
            background: linear-gradient(180deg, rgba(17,24,42,.85), rgba(15,22,38,.75));
            padding: 16px;
            position: relative;
            overflow: visible;
            display: flex;
            flex-direction: column;
            transition: border-color .2s ease;
        }
        .v2-heroCard:hover { border-color: rgba(96,165,250,.25); }
        .v2-heroCard::before {
            content: '';
            position: absolute;
            left: 0; top: 0; bottom: 0;
            width: 3px;
            border-radius: 18px 0 0 18px;
        }
        .v2-heroCard.urgency-act_now::before { background: var(--red, #fb7185); box-shadow: 0 0 12px rgba(251,113,133,.4); animation: v2UrgencyPulse 2.5s ease-in-out infinite; }
        .v2-heroCard.urgency-act_now { border-color: rgba(251,113,133,.20); }
        .v2-heroCard.urgency-this_week::before { background: var(--yellow, #fbbf24); box-shadow: 0 0 8px rgba(251,191,36,.25); }
        .v2-heroCard.urgency-this_week { border-color: rgba(251,191,36,.15); }
        .v2-heroCard.urgency-this_month::before { background: var(--text-muted); opacity: .4; }

        @keyframes v2UrgencyPulse {
            0%, 100% { box-shadow: 0 0 8px rgba(251,113,133,.3); }
            50% { box-shadow: 0 0 18px rgba(251,113,133,.5); }
        }

        .v2-heroTop {
            display: flex;
            align-items: flex-start;
            justify-content: space-between;
            gap: 10px;
            margin-bottom: 8px;
        }

        /* ── V2 Badges ── */
        .v2-badgeRow { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
        .v2-badge {
            font-size: 10.5px;
            font-weight: 800;
            letter-spacing: .3px;
            padding: 5px 8px;
            border-radius: 999px;
            border: 1px solid rgba(255,255,255,.06);
            text-transform: uppercase;
            display: inline-flex;
            align-items: center;
            gap: 6px;
            background: rgba(17,24,42,.5);
        }
        .v2-badge .dot { width: 7px; height: 7px; border-radius: 999px; }
        .v2-badge.quick { background: rgba(52,211,153,.12); border-color: rgba(52,211,153,.25); color: #6ee7b7; }
        .v2-badge.quick .dot { background: var(--green); }
        .v2-badge.retention { background: rgba(251,113,133,.12); border-color: rgba(251,113,133,.25); color: #fda4af; }
        .v2-badge.retention .dot { background: var(--red, #fb7185); }
        .v2-badge.performance { background: rgba(96,165,250,.12); border-color: rgba(96,165,250,.25); color: #93c5fd; }
        .v2-badge.performance .dot { background: var(--blue, #60a5fa); }

        .v2-urgLabel {
            font-size: 10.5px;
            font-weight: 800;
            padding: 5px 8px;
            border-radius: 999px;
            border: 1px solid rgba(255,255,255,.06);
            text-transform: uppercase;
            letter-spacing: .2px;
            display: inline-flex;
            align-items: center;
            gap: 6px;
        }
        .v2-urgLabel .ico { width: 7px; height: 7px; border-radius: 999px; }
        .v2-urgLabel.act_now { color: var(--red, #fb7185); border-color: rgba(251,113,133,.25); }
        .v2-urgLabel.act_now .ico { background: var(--red, #fb7185); }
        .v2-urgLabel.this_week { color: var(--yellow, #fbbf24); border-color: rgba(251,191,36,.20); }
        .v2-urgLabel.this_week .ico { background: var(--yellow, #fbbf24); }
        .v2-urgLabel.this_month { color: var(--text-muted); border-color: rgba(159,176,208,.15); }
        .v2-urgLabel.this_month .ico { background: var(--text-muted); }

        .v2-effortTag {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            font-size: 10.5px;
            font-weight: 700;
            color: var(--text-muted);
            padding: 4px 8px;
            border-radius: 999px;
            border: 1px solid rgba(255,255,255,.05);
            background: rgba(17,24,42,.4);
        }
        .v2-effortTag .dot { width: 6px; height: 6px; border-radius: 999px; }
        .v2-effortTag.low .dot { background: var(--green); }
        .v2-effortTag.medium .dot { background: var(--yellow, #fbbf24); }
        .v2-effortTag.high .dot { background: #94a3b8; }

        .v2-money { font-weight: 900; font-size: 17px; text-align: right; min-width: 80px; letter-spacing: -.3px; }
        .v2-money small { display: block; font-size: 10.5px; color: var(--text-muted); font-weight: 700; margin-top: 1px; }

        .v2-clientName { font-size: 15px; font-weight: 900; margin: 6px 0 2px; }
        .v2-clientName .hcp { font-size: 11.5px; color: var(--text-muted); font-weight: 700; margin-left: 6px; }

        .v2-signals { display: flex; flex-wrap: wrap; gap: 5px; margin: 8px 0; }
        .v2-tag {
            font-size: 10.5px;
            color: var(--text-muted);
            padding: 4px 8px;
            background: rgba(17,24,42,.5);
            border: 1px solid rgba(255,255,255,.05);
            border-radius: 999px;
            white-space: nowrap;
            font-weight: 600;
        }
        .v2-tag.hot { border-color: rgba(45,212,191,.22); color: rgba(232,238,252,.88); }
        .v2-tag.risk { border-color: rgba(251,113,133,.20); color: rgba(232,238,252,.88); }

        .v2-blurb {
            color: var(--text-muted);
            font-size: 12px;
            line-height: 1.45;
            margin: 4px 0 12px;
        }
        .v2-blurb b { color: var(--text-primary); font-weight: 700; }

        .v2-heroActions {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
            margin-top: auto;
        }

        .v2-creditCost { display: block; font-size: 9.5px; color: var(--text-muted); font-weight: 600; margin-top: 1px; letter-spacing: .1px; }

        /* ── V2 Status Chip ── */
        .v2-statusChip {
            display: inline-flex;
            align-items: center;
            gap: 5px;
            font-size: 10px;
            font-weight: 800;
            padding: 4px 8px;
            border-radius: 999px;
            text-transform: uppercase;
            letter-spacing: .2px;
        }
        .v2-statusChip.presented { background: rgba(96,165,250,.10); border: 1px solid rgba(96,165,250,.25); color: var(--blue, #60a5fa); }
        .v2-statusChip.converted { background: rgba(45,212,191,.10); border: 1px solid rgba(45,212,191,.25); color: var(--green); }
        .v2-statusChip.lost { background: rgba(251,113,133,.08); border: 1px solid rgba(251,113,133,.20); color: var(--red, #fb7185); opacity: .7; }
        .v2-statusChip.deferred { background: rgba(251,191,36,.08); border: 1px solid rgba(251,191,36,.18); color: var(--yellow, #fbbf24); opacity: .7; }

        /* ── V2 Outcome Banner ── */
        .v2-outcomeBanner {
            display: none;
            align-items: center;
            justify-content: space-between;
            gap: 10px;
            padding: 10px 14px;
            margin-top: 10px;
            border-radius: 12px;
            border: 1px solid rgba(45,212,191,.20);
            background: rgba(45,212,191,.06);
            font-size: 12px;
            font-weight: 700;
            color: var(--text-primary);
            flex-wrap: wrap;
        }
        .v2-outcomeBanner.show { display: flex; }
        .v2-outcomeBanner .v2-outcomeBtns { display: flex; gap: 6px; flex-wrap: wrap; }

        /* ── V2 All Opportunities Card ── */
        .v2-allCard {
            background: linear-gradient(180deg, rgba(17,24,42,.82), rgba(15,22,38,.80));
            border: 1px solid var(--border-light);
            border-radius: 18px;
            box-shadow: 0 10px 30px rgba(0,0,0,.35);
            margin-top: 14px;
        }
        .v2-allHeader {
            padding: 14px 16px;
            border-bottom: 1px solid rgba(31,42,68,.6);
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
        }
        .v2-allHeader h2 { font-size: 13.5px; font-weight: 800; margin: 0; }

        .v2-controls {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            flex-wrap: wrap;
            padding: 10px 16px;
            border-bottom: 1px solid rgba(31,42,68,.5);
            background: rgba(15,22,38,.3);
        }
        .v2-filters { display: flex; gap: 6px; flex-wrap: wrap; }
        .v2-filterBtn {
            cursor: pointer;
            border: 1px solid rgba(31,42,68,.85);
            background: rgba(17,24,42,.5);
            color: var(--text-muted);
            padding: 7px 10px;
            border-radius: 999px;
            font-size: 11.5px;
            font-weight: 700;
            transition: all .15s ease;
            font-family: inherit;
        }
        .v2-filterBtn:hover { border-color: #2b3a60; color: var(--text-primary); }
        .v2-filterBtn.active {
            color: var(--text-primary);
            border-color: rgba(96,165,250,.35);
            background: rgba(96,165,250,.08);
        }

        .v2-rightControls {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
            align-items: center;
        }
        #v2-searchInput, #v2-sortSelect {
            border: 1px solid rgba(31,42,68,.9);
            background: rgba(17,24,42,.5);
            color: var(--text-primary);
            border-radius: 10px;
            padding: 8px 10px;
            font-size: 12px;
            font-family: inherit;
            outline: none;
        }
        #v2-searchInput::placeholder { color: rgba(159,176,208,.5); }
        #v2-searchInput:focus, #v2-sortSelect:focus { box-shadow: 0 0 0 3px rgba(96,165,250,.35); }

        .v2-listBody { padding: 10px 16px 16px; }
        .v2-list { display: grid; gap: 8px; }
        .v2-footerRow { display: flex; justify-content: center; margin-top: 12px; }

        /* ── V2 Row Cards (list items) ── */
        .v2-rowCard {
            padding: 12px 14px;
            border-radius: 14px;
            border: 1px solid rgba(31,42,68,.8);
            background: rgba(15,22,38,.45);
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            align-items: flex-start;
            justify-content: space-between;
            position: relative;
            transition: border-color .15s ease;
        }
        .v2-rowCard:hover { border-color: rgba(96,165,250,.15); }
        .v2-rowCard::before {
            content: '';
            position: absolute;
            left: 0; top: 8px; bottom: 8px;
            width: 2px;
            border-radius: 2px;
        }
        .v2-rowCard.urgency-act_now::before { background: var(--red, #fb7185); }
        .v2-rowCard.urgency-this_week::before { background: var(--yellow, #fbbf24); opacity: .7; }
        .v2-rowCard.urgency-this_month::before { background: var(--text-muted); opacity: .25; }

        .v2-rowLeft { min-width: 0; flex: 1 1 auto; }
        .v2-rowTop { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 4px; }
        .v2-rowTitle { font-weight: 900; font-size: 13px; }
        .v2-rowTitle .hcp { font-size: 11px; color: var(--text-muted); font-weight: 700; margin-left: 4px; }
        .v2-rowSub { color: var(--text-muted); font-size: 11.5px; margin-top: 3px; line-height: 1.35; }

        .v2-rowRight {
            display: flex;
            flex-direction: column;
            align-items: flex-end;
            gap: 8px;
            min-width: 200px;
            flex-shrink: 0;
        }
        .v2-rowRight .v2-money { font-size: 14px; }
        .v2-rowBtns { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }

        .v2-reasoning {
            margin-top: 8px;
            border-top: 1px dashed rgba(31,42,68,.6);
            padding-top: 8px;
        }
        .v2-reasoning summary {
            cursor: pointer;
            color: rgba(232,238,252,.85);
            font-size: 11.5px;
            font-weight: 700;
            list-style: none;
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .v2-reasoning summary::-webkit-details-marker { display: none; }
        .v2-reasoning .v2-reasoning-body {
            margin-top: 6px;
            font-size: 12px;
            color: var(--text-muted);
            line-height: 1.45;
        }

        /* ── V2 Overlay / Modal ── */
        .v2-overlay {
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,.55);
            backdrop-filter: blur(4px);
            display: none;
            align-items: center;
            justify-content: center;
            padding: 18px;
            z-index: 50;
        }
        .v2-overlay.show { display: flex; }
        .v2-modal {
            width: min(800px, 100%);
            border-radius: 18px;
            background: linear-gradient(180deg, rgba(17,24,42,.98), rgba(15,22,38,.98));
            border: 1px solid rgba(31,42,68,.9);
            box-shadow: 0 10px 30px rgba(0,0,0,.35);
            overflow: hidden;
        }
        .v2-modal-header {
            padding: 14px 16px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            border-bottom: 1px solid rgba(31,42,68,.7);
        }
        .v2-modal-header .title { font-weight: 900; font-size: 13.5px; }
        .v2-modal-body { padding: 14px 16px 16px; }
        .v2-field { margin-bottom: 12px; }
        .v2-field .v2-field-label { font-size: 11.5px; color: var(--text-muted); font-weight: 700; margin-bottom: 5px; }
        .v2-field input {
            width: 100%;
            border: 1px solid rgba(31,42,68,.9);
            background: rgba(11,15,25,.5);
            color: var(--text-primary);
            padding: 10px 12px;
            border-radius: 12px;
            font-size: 13px;
            font-family: inherit;
            outline: none;
        }
        .v2-field input:focus { box-shadow: 0 0 0 3px rgba(96,165,250,.35); }
        .v2-textarea {
            width: 100%;
            min-height: 200px;
            resize: vertical;
            border-radius: 12px;
            border: 1px solid rgba(31,42,68,.9);
            background: rgba(11,15,25,.5);
            color: var(--text-primary);
            padding: 12px;
            font-size: 12.5px;
            line-height: 1.45;
            font-family: inherit;
            outline: none;
        }
        .v2-textarea:focus { box-shadow: 0 0 0 3px rgba(96,165,250,.35); }
        .v2-modal-footer {
            padding: 12px 16px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            border-top: 1px solid rgba(31,42,68,.7);
            background: rgba(15,22,38,.5);
        }
        .v2-hint { color: var(--text-muted); font-size: 11.5px; line-height: 1.3; }

        /* ── V2 Toast ── */
        .v2-toast {
            position: fixed;
            left: 50%; bottom: 20px;
            transform: translateX(-50%) translateY(20px);
            background: rgba(17,24,42,.92);
            border: 1px solid rgba(31,42,68,.9);
            color: var(--text-primary);
            padding: 10px 16px;
            border-radius: 999px;
            box-shadow: 0 10px 30px rgba(0,0,0,.35);
            z-index: 60;
            font-size: 12.5px;
            font-weight: 700;
            opacity: 0;
            pointer-events: none;
            transition: opacity .2s ease, transform .2s ease;
        }
        .v2-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }

        /* ── V2 Tooltips ── */
        [data-tooltip] {
            position: relative;
        }
        [data-tooltip]:hover::after {
            content: attr(data-tooltip);
            position: absolute;
            bottom: calc(100% + 8px);
            left: 50%;
            transform: translateX(-50%);
            background: #1a1d29;
            color: #e4e4f0;
            padding: 6px 12px;
            border-radius: 6px;
            font-size: 12px;
            max-width: 250px;
            white-space: normal;
            z-index: 1000;
            border: 1px solid rgba(255,255,255,0.12);
            pointer-events: none;
            animation: tooltipFade 0.2s ease 0.3s both;
            text-align: center;
            line-height: 1.4;
        }
        @keyframes tooltipFade {
            from { opacity: 0; } to { opacity: 1; }
        }
        [data-tooltip-position="bottom"]:hover::after {
            bottom: auto;
            top: calc(100% + 8px);
        }

        /* ── V2 Message Preview ── */
        .v2-msgPreview {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.2s ease;
        }
        .v2-msgPreview.show {
            max-height: 300px;
        }
        .v2-msgPreview-inner {
            padding: 10px 0 0;
        }
        .v2-msgPreview-text {
            background: rgba(0,0,0,0.25);
            border-left: 3px solid var(--border-light);
            padding: 10px 14px;
            border-radius: 0 6px 6px 0;
            font-size: 13px;
            line-height: 1.55;
            color: var(--text-secondary, #b0b3c6);
            white-space: pre-wrap;
            word-break: break-word;
            max-height: 160px;
            overflow-y: auto;
        }
        .v2-heroCard.urgency-act_now .v2-msgPreview-text { border-left-color: var(--red, #fb7185); }
        .v2-heroCard.urgency-this_week .v2-msgPreview-text,
        .v2-rowCard.urgency-this_week .v2-msgPreview-text { border-left-color: var(--yellow, #fbbf24); }
        .v2-heroCard.urgency-this_month .v2-msgPreview-text,
        .v2-rowCard.urgency-this_month .v2-msgPreview-text { border-left-color: var(--blue, #60a5fa); }
        .v2-rowCard.urgency-act_now .v2-msgPreview-text { border-left-color: var(--red, #fb7185); }
        .v2-msgPreview-btns {
            display: flex;
            gap: 8px;
            margin-top: 8px;
        }

        /* Channel pill selector */
        .v2-channelPills { display: flex; gap: 6px; flex-wrap: wrap; }
        .v2-channelPill {
            padding: 6px 14px;
            border-radius: 20px;
            border: 1px solid var(--border-light, #2a2d3e);
            background: transparent;
            color: var(--text-secondary, #b0b3c6);
            font-size: 13px;
            cursor: pointer;
            transition: all 0.15s ease;
        }
        .v2-channelPill:hover { border-color: rgba(45,212,191,.35); color: var(--text-primary, #e0e2f0); }
        .v2-channelPill.active {
            border-color: rgba(45,212,191,.5);
            background: rgba(45,212,191,.12);
            color: var(--accent, #2dd4bf);
        }

        /* Button variants */
        .v2-btn-success {
            border-color: rgba(34,197,94,.4);
            background: rgba(34,197,94,.15);
            color: #22c55e;
        }
        .v2-btn-success:hover { background: rgba(34,197,94,.25); }
        .v2-btn-danger-outline {
            border: 1px solid rgba(251,113,133,.4);
            background: transparent;
            color: var(--red, #fb7185);
        }
        .v2-btn-danger-outline:hover { background: rgba(251,113,133,.1); }
        .v2-btn-warning-outline {
            border: 1px solid rgba(251,191,36,.4);
            background: transparent;
            color: var(--yellow, #fbbf24);
        }
        .v2-btn-warning-outline:hover { background: rgba(251,191,36,.1); }

        /* Send history on cards */
        .v2-sendHistory {
            margin: 6px 0;
            padding: 0;
            list-style: none;
            font-size: 12px;
            color: var(--text-secondary, #b0b3c6);
        }
        .v2-sendHistory-item {
            display: flex;
            align-items: center;
            gap: 6px;
            padding: 2px 0;
            opacity: 0.8;
        }
        .v2-sendHistory-item .hist-icon { font-size: 11px; }
        .v2-sendHistory-item .hist-label { flex: 1; }
        .v2-sendHistory-item .hist-time { font-size: 11px; opacity: 0.7; }

        /* Pro Nav Tabs */
        /* Pro Menu Tabs */
        .pro-tabs {
            display: none;
            gap: 4px;
            background: var(--bg-card);
            border-radius: 10px;
            padding: 4px;
            margin-bottom: 20px;
            overflow: visible;
        }

        body.pro-view .pro-tabs {
            display: flex;
        }

        .pro-tab {
            flex: 1;
            padding: 12px 16px;
            text-align: center;
            font-size: 13px;
            color: var(--text-muted);
            cursor: pointer;
            border-radius: 8px;
            transition: all 0.2s;
            white-space: nowrap;
            border: none;
            background: transparent;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 6px;
        }

        .pro-tab:hover {
            background: var(--bg-main);
            color: var(--text-secondary);
        }

        .pro-tab.active {
            background: var(--cyan-dim);
            color: var(--cyan);
            font-weight: 600;
        }

        .pro-tab .badge {
            display: inline-block;
            background: var(--cyan);
            color: #000;
            font-size: 10px;
            padding: 2px 6px;
            border-radius: 8px;
        }

        /* Mobile: Scroll horizontally if needed */
        @media (max-width: 600px) {
            .pro-tabs {
                overflow-x: auto;
                -webkit-overflow-scrolling: touch;
            }
            
            .pro-tab {
                padding: 10px 12px;
                font-size: 12px;
                min-width: fit-content;
            }
        }

        /* Hide old nav styles */
        .pro-nav-tabs,
        .pro-menu-header {
            display: none !important;
        }

        /* ============================================
           SETTINGS PAGE
           ============================================ */
        .settings-header {
            margin-bottom: 24px;
        }

        .settings-title {
            font-size: 24px;
            font-weight: 700;
            margin-bottom: 4px;
        }

        .settings-subtitle {
            font-size: 14px;
            color: var(--text-muted);
        }

        .settings-section {
            background: var(--bg-card);
            border-radius: 14px;
            padding: 20px;
            margin-bottom: 20px;
            border: 1px solid var(--border-light);
        }

        .settings-section-title {
            font-size: 16px;
            font-weight: 600;
            margin-bottom: 16px;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .settings-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 14px 0;
            border-bottom: 1px solid var(--border-light);
        }

        .settings-row:last-child {
            border-bottom: none;
            padding-bottom: 0;
        }

        .settings-row:first-of-type {
            padding-top: 0;
        }

        .settings-label {
            font-size: 14px;
            color: var(--text-secondary);
        }

        .settings-label-hint {
            font-size: 12px;
            color: var(--text-dim);
            margin-top: 4px;
        }

        .settings-input {
            padding: 10px 14px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 14px;
            min-width: 200px;
        }

        .settings-input:focus {
            outline: none;
            border-color: var(--cyan);
        }

        .settings-select {
            padding: 10px 14px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 8px;
            color: var(--text-primary);
            font-size: 14px;
            min-width: 180px;
            cursor: pointer;
        }

        .settings-select:focus {
            outline: none;
            border-color: var(--cyan);
        }

        /* Autocomplete Styles */
        .autocomplete-wrapper {
            position: relative;
            width: 100%;
        }

        .autocomplete-dropdown {
            display: none;
            position: absolute;
            top: 100%;
            left: 0;
            right: 0;
            background: var(--bg-card);
            border: 1px solid var(--border-medium);
            border-top: none;
            border-radius: 0 0 8px 8px;
            max-height: 200px;
            overflow-y: auto;
            z-index: 1001;
            box-shadow: 0 4px 12px rgba(0,0,0,0.3);
        }

        .autocomplete-dropdown.show {
            display: block;
        }

        .autocomplete-item {
            padding: 10px 14px;
            cursor: pointer;
            font-size: 14px;
            color: var(--text-primary);
            border-bottom: 1px solid var(--border-light);
        }

        .autocomplete-item:last-child {
            border-bottom: none;
        }

        .autocomplete-item:hover {
            background: var(--cyan);
            color: #000;
        }

        .autocomplete-item .item-subtitle {
            font-size: 11px;
            color: var(--text-muted);
        }

        .autocomplete-item:hover .item-subtitle {
            color: #333;
        }

        .color-picker-row {
            display: flex;
            gap: 10px;
        }

        .color-swatch {
            width: 36px;
            height: 36px;
            border-radius: 8px;
            cursor: pointer;
            border: 2px solid transparent;
            transition: all 0.2s;
        }

        .color-swatch:hover {
            transform: scale(1.1);
        }

        .color-swatch.active {
            border-color: #fff;
            box-shadow: 0 0 0 2px var(--cyan);
        }

        .settings-toggle {
            position: relative;
            width: 50px;
            height: 28px;
            background: var(--bg-main);
            border-radius: 14px;
            cursor: pointer;
            transition: background 0.2s;
            border: 1px solid var(--border-medium);
        }

        .settings-toggle.active {
            background: var(--cyan);
            border-color: var(--cyan);
        }

        .settings-toggle::after {
            content: '';
            position: absolute;
            width: 22px;
            height: 22px;
            background: #fff;
            border-radius: 50%;
            top: 2px;
            left: 2px;
            transition: transform 0.2s;
        }

        .settings-toggle.active::after {
            transform: translateX(22px);
        }

        /* Range Slider */
        input[type="range"] {
            -webkit-appearance: none;
            appearance: none;
            height: 6px;
            background: var(--bg-main);
            border-radius: 3px;
            outline: none;
        }

        input[type="range"]::-webkit-slider-thumb {
            -webkit-appearance: none;
            appearance: none;
            width: 16px;
            height: 16px;
            background: var(--cyan);
            border-radius: 50%;
            cursor: pointer;
            transition: transform 0.15s;
        }

        input[type="range"]::-webkit-slider-thumb:hover {
            transform: scale(1.15);
        }

        input[type="range"]::-moz-range-thumb {
            width: 16px;
            height: 16px;
            background: var(--cyan);
            border-radius: 50%;
            cursor: pointer;
            border: none;
        }

        .demo-notice {
            background: rgba(138, 43, 226, 0.15);
            border: 1px solid rgba(138, 43, 226, 0.3);
            border-radius: 10px;
            padding: 14px;
            margin-bottom: 20px;
            font-size: 13px;
            color: var(--purple);
        }

        .preview-box {
            background: var(--bg-main);
            border-radius: 10px;
            padding: 16px;
            margin-top: 16px;
        }

        .preview-label {
            font-size: 11px;
            color: var(--text-muted);
            margin-bottom: 8px;
        }

        .preview-header {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 10px 14px;
            background: var(--bg-card);
            border-radius: 8px;
        }

        .preview-logo {
            font-size: 14px;
            font-weight: 700;
        }

        .preview-powered {
            font-size: 10px;
            color: var(--text-muted);
        }

        /* ============================================
           GHIN / HANDICAP
           ============================================ */
        .handicap-container {
            max-width: 600px;
            margin: 0 auto;
        }

        .ghin-card {
            background: var(--bg-card);
            border-radius: 14px;
            padding: 20px;
            margin-bottom: 20px;
            border: 1px solid var(--border-light);
        }

        .ghin-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            margin-bottom: 16px;
        }

        .ghin-title {
            font-size: 16px;
            font-weight: 600;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .ghin-status {
            font-size: 11px;
            padding: 4px 10px;
            border-radius: 10px;
        }

        .ghin-status.connected {
            background: var(--green-dim);
            color: var(--green);
        }

        .ghin-status.not-connected {
            background: rgba(255,255,255,0.1);
            color: var(--text-muted);
        }

        .ghin-input-row {
            display: flex;
            gap: 12px;
            margin-bottom: 16px;
        }

        .ghin-input {
            flex: 1;
            padding: 12px 16px;
            background: var(--bg-main);
            border: 2px solid var(--border-medium);
            border-radius: 10px;
            color: var(--text-primary);
            font-size: 16px;
            letter-spacing: 1px;
        }

        .ghin-input:focus {
            outline: none;
            border-color: var(--cyan);
        }

        .ghin-input::placeholder {
            color: var(--text-dim);
            letter-spacing: 0;
        }

        .btn-sync {
            padding: 12px 20px;
            background: var(--cyan);
            border: none;
            border-radius: 10px;
            color: #000;
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            white-space: nowrap;
            transition: all 0.2s;
        }

        .btn-sync:hover {
            opacity: 0.9;
        }

        .btn-sync:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }

        .ghin-last-sync {
            font-size: 12px;
            color: var(--text-dim);
        }

        /* Handicap Display */
        .handicap-display {
            text-align: center;
            padding: 24px;
            background: linear-gradient(135deg, rgba(0, 212, 255, 0.1), rgba(138, 43, 226, 0.1));
            border-radius: 14px;
            margin-bottom: 20px;
        }

        .handicap-label {
            font-size: 12px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
            margin-bottom: 8px;
        }

        .handicap-value {
            font-size: 56px;
            font-weight: 800;
            color: var(--cyan);
            line-height: 1;
            margin-bottom: 8px;
        }

        .handicap-trend {
            font-size: 14px;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 6px;
        }

        .handicap-trend.improving {
            color: var(--green);
        }

        .handicap-trend.declining {
            color: var(--red);
        }

        .handicap-trend.stable {
            color: var(--text-muted);
        }

        /* Trend Chart */
        .trend-card {
            background: var(--bg-card);
            border-radius: 14px;
            padding: 20px;
            margin-bottom: 20px;
            border: 1px solid var(--border-light);
        }

        .trend-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 16px;
        }

        .trend-title {
            font-size: 16px;
            font-weight: 600;
        }

        .trend-period {
            display: flex;
            gap: 6px;
        }

        .trend-period-btn {
            padding: 6px 12px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 6px;
            color: var(--text-muted);
            font-size: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .trend-period-btn.active {
            background: var(--cyan-dim);
            border-color: var(--cyan);
            color: var(--cyan);
        }

        .trend-chart {
            height: 160px;
            background: var(--bg-main);
            border-radius: 10px;
            padding: 16px;
            position: relative;
            overflow: hidden;
        }

        .chart-line {
            position: absolute;
            bottom: 20px;
            left: 20px;
            right: 20px;
            height: 100px;
        }

        .chart-svg {
            width: 100%;
            height: 100%;
        }

        .chart-path {
            fill: none;
            stroke: var(--cyan);
            stroke-width: 3;
            stroke-linecap: round;
            stroke-linejoin: round;
        }

        .chart-area {
            fill: url(#chartGradient);
            opacity: 0.3;
        }

        .chart-labels {
            display: flex;
            justify-content: space-between;
            margin-top: 8px;
            font-size: 10px;
            color: var(--text-dim);
        }

        .chart-y-labels {
            position: absolute;
            left: 0;
            top: 16px;
            bottom: 36px;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            font-size: 10px;
            color: var(--text-dim);
        }

        /* Recent Rounds */
        .rounds-card {
            background: var(--bg-card);
            border-radius: 14px;
            padding: 20px;
            border: 1px solid var(--border-light);
        }

        .rounds-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 16px;
        }

        .rounds-title {
            font-size: 16px;
            font-weight: 600;
        }

        .rounds-link {
            font-size: 13px;
            color: var(--cyan);
            cursor: pointer;
        }

        .round-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 14px;
            background: var(--bg-main);
            border-radius: 10px;
            margin-bottom: 10px;
        }

        .round-item:last-child {
            margin-bottom: 0;
        }

        .round-info {
            flex: 1;
        }

        .round-course {
            font-size: 14px;
            font-weight: 500;
            margin-bottom: 4px;
        }

        .round-meta {
            font-size: 12px;
            color: var(--text-muted);
        }

        .round-score {
            text-align: right;
        }

        .round-score-value {
            font-size: 24px;
            font-weight: 700;
        }

        .round-score-value.good {
            color: var(--green);
        }

        .round-score-value.avg {
            color: var(--text-primary);
        }

        .round-score-value.poor {
            color: var(--yellow);
        }

        .round-differential {
            font-size: 11px;
            color: var(--text-muted);
        }

        .no-ghin-message {
            text-align: center;
            padding: 40px 20px;
            color: var(--text-muted);
        }

        .no-ghin-icon {
            font-size: 48px;
            margin-bottom: 16px;
            opacity: 0.5;
        }

        .no-ghin-text {
            font-size: 14px;
            margin-bottom: 8px;
        }

        .no-ghin-hint {
            font-size: 12px;
            color: var(--text-dim);
        }

        /* Collapsible Sections */
        .collapsible-section {
            background: var(--bg-card);
            border-radius: 14px;
            margin-bottom: 12px;
            border: 1px solid var(--border-light);
            overflow: hidden;
        }

        .collapsible-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 16px 20px;
            cursor: pointer;
            transition: background 0.2s;
        }

        .collapsible-header:hover {
            background: rgba(255,255,255,0.03);
        }

        .collapsible-title {
            font-size: 15px;
            font-weight: 600;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .collapsible-count {
            font-size: 12px;
            color: var(--text-muted);
            font-weight: 400;
        }

        .collapsible-arrow {
            font-size: 12px;
            color: var(--text-muted);
            transition: transform 0.2s;
        }

        .collapsible-section.open .collapsible-arrow {
            transform: rotate(180deg);
        }

        .collapsible-content {
            display: none;
            padding: 0 20px 16px;
            border-top: 1px solid var(--border-light);
        }

        .collapsible-section.open .collapsible-content {
            display: block;
        }

        /* Lesson Items */
        .lesson-item {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            padding: 14px 0;
            border-bottom: 1px solid var(--border-light);
        }

        .lesson-item:last-child {
            border-bottom: none;
            padding-bottom: 0;
        }

        .lesson-item:first-child {
            padding-top: 14px;
        }

        .lesson-info {
            flex: 1;
        }

        .lesson-type {
            font-size: 14px;
            font-weight: 500;
            margin-bottom: 4px;
        }

        .lesson-meta {
            font-size: 12px;
            color: var(--text-muted);
        }

        .lesson-notes {
            font-size: 13px;
            color: var(--text-secondary);
            margin-top: 6px;
            font-style: italic;
        }

        .lesson-badge {
            font-size: 11px;
            padding: 4px 10px;
            border-radius: 10px;
            background: var(--purple-dim);
            color: var(--purple);
        }

        /* Bag Change Items */
        .bag-change-item {
            display: flex;
            align-items: flex-start;
            gap: 12px;
            padding: 14px 0;
            border-bottom: 1px solid var(--border-light);
        }

        .bag-change-item:last-child {
            border-bottom: none;
        }

        .bag-change-icon {
            width: 36px;
            height: 36px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 16px;
            flex-shrink: 0;
        }

        .bag-change-icon.upgrade {
            background: var(--green-dim);
        }

        .bag-change-icon.added {
            background: var(--cyan-dim);
        }

        .bag-change-icon.removed {
            background: rgba(255,100,100,0.15);
        }

        .bag-change-info {
            flex: 1;
        }

        .bag-change-title {
            font-size: 14px;
            font-weight: 500;
            margin-bottom: 4px;
        }

        .bag-change-detail {
            font-size: 12px;
            color: var(--text-muted);
        }

        .bag-change-grade {
            text-align: right;
        }

        .grade-change {
            font-size: 13px;
            font-weight: 600;
        }

        .grade-change.positive {
            color: var(--green);
        }

        .grade-change.negative {
            color: var(--red);
        }

        /* Chart Legend */
        .chart-legend {
            display: flex;
            justify-content: center;
            gap: 20px;
            margin-top: 16px;
            flex-wrap: wrap;
        }

        .legend-item {
            display: flex;
            align-items: center;
            gap: 6px;
            font-size: 11px;
            color: var(--text-muted);
        }

        .legend-dot {
            width: 10px;
            height: 10px;
            border-radius: 50%;
        }

        .legend-dot.rounds {
            background: var(--cyan);
        }

        .legend-dot.lessons {
            background: var(--purple);
        }

        .legend-dot.equipment {
            background: var(--green);
        }

        /* ============================================
           MESSAGING
           ============================================ */
        .messages-container {
            max-width: 600px;
            margin: 0 auto;
            display: flex;
            flex-direction: column;
            height: calc(100vh - 350px);
            min-height: 400px;
        }

        .messages-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 16px;
        }

        .messages-title {
            font-size: 16px;
            font-weight: 600;
        }

        .messages-list {
            flex: 1;
            overflow-y: auto;
            padding: 16px;
            background: var(--bg-card);
            border-radius: 14px;
            margin-bottom: 16px;
        }

        .message-item {
            margin-bottom: 16px;
            display: flex;
            flex-direction: column;
        }

        .message-item.sent {
            align-items: flex-end;
        }

        .message-item.received {
            align-items: flex-start;
        }

        .message-bubble {
            max-width: 80%;
            padding: 12px 16px;
            border-radius: 16px;
            font-size: 14px;
            line-height: 1.5;
        }

        .message-item.sent .message-bubble {
            background: var(--cyan);
            color: #000;
            border-bottom-right-radius: 4px;
        }

        .message-item.received .message-bubble {
            background: var(--bg-main);
            color: var(--text-primary);
            border-bottom-left-radius: 4px;
        }

        .message-meta {
            font-size: 11px;
            color: var(--text-dim);
            margin-top: 4px;
            padding: 0 4px;
        }

        .message-input-area {
            display: flex;
            gap: 12px;
            padding: 16px;
            background: var(--bg-card);
            border-radius: 14px;
        }

        .message-input {
            flex: 1;
            padding: 12px 16px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 24px;
            color: var(--text-primary);
            font-size: 14px;
            resize: none;
        }

        .message-input:focus {
            outline: none;
            border-color: var(--cyan);
        }

        .message-input::placeholder {
            color: var(--text-dim);
        }

        .btn-send {
            width: 44px;
            height: 44px;
            border-radius: 50%;
            background: var(--cyan);
            border: none;
            color: #000;
            font-size: 18px;
            cursor: pointer;
            transition: all 0.2s;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .btn-send:hover {
            opacity: 0.9;
            transform: scale(1.05);
        }

        .btn-send:disabled {
            opacity: 0.5;
            cursor: not-allowed;
            transform: none;
        }

        /* Notification Badge */
        .tab-badge {
            display: inline-block;
            background: var(--red);
            color: #fff;
            font-size: 10px;
            font-weight: 700;
            padding: 2px 6px;
            border-radius: 10px;
            margin-left: 6px;
            min-width: 16px;
            text-align: center;
        }

        .nav-badge {
            position: absolute;
            top: -4px;
            right: -4px;
            background: var(--red);
            color: #fff;
            font-size: 10px;
            font-weight: 700;
            padding: 2px 6px;
            border-radius: 10px;
            min-width: 16px;
            text-align: center;
        }

        /* Quick Actions in Messages */
        .quick-actions {
            display: flex;
            gap: 8px;
            margin-bottom: 16px;
            flex-wrap: wrap;
        }

        .quick-action-btn {
            padding: 8px 14px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 20px;
            color: var(--text-muted);
            font-size: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .quick-action-btn:hover {
            border-color: var(--cyan);
            color: var(--cyan);
        }

        /* ============================================
           CLIENT ONBOARDING
           ============================================ */
        .onboarding-modal {
            max-width: 500px;
            width: 90%;
        }

        .onboarding-step {
            display: none;
        }

        .onboarding-step.active {
            display: block;
        }

        .onboarding-progress {
            display: flex;
            justify-content: center;
            gap: 8px;
            margin-bottom: 24px;
        }

        .onboarding-dot {
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background: var(--border-medium);
            transition: all 0.2s;
        }

        .onboarding-dot.active {
            background: var(--cyan);
            transform: scale(1.2);
        }

        .onboarding-dot.complete {
            background: var(--green);
        }

        .invite-code-display {
            background: var(--bg-main);
            border: 2px dashed var(--cyan);
            border-radius: 12px;
            padding: 20px;
            text-align: center;
            margin: 20px 0;
        }

        .invite-code {
            font-size: 28px;
            font-weight: 800;
            letter-spacing: 4px;
            color: var(--cyan);
            margin-bottom: 8px;
        }

        .invite-code-hint {
            font-size: 12px;
            color: var(--text-muted);
        }

        .invite-link-box {
            background: var(--bg-main);
            border-radius: 10px;
            padding: 12px;
            display: flex;
            gap: 10px;
            margin: 16px 0;
        }

        .invite-link-input {
            flex: 1;
            background: transparent;
            border: none;
            color: var(--text-primary);
            font-size: 13px;
        }

        .invite-link-input:focus {
            outline: none;
        }

        .btn-copy {
            padding: 8px 16px;
            background: var(--cyan);
            border: none;
            border-radius: 6px;
            color: #000;
            font-size: 12px;
            font-weight: 600;
            cursor: pointer;
        }

        .btn-copy:hover {
            opacity: 0.9;
        }

        .share-options {
            display: flex;
            justify-content: center;
            gap: 16px;
            margin-top: 20px;
        }

        .share-btn {
            width: 50px;
            height: 50px;
            border-radius: 50%;
            border: none;
            font-size: 24px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .share-btn:hover {
            transform: scale(1.1);
        }

        .share-btn.email {
            background: #EA4335;
            color: #fff;
        }

        .share-btn.sms {
            background: #34C759;
            color: #fff;
        }

        .share-btn.copy {
            background: var(--bg-card);
            color: var(--cyan);
            border: 1px solid var(--border-medium);
        }

        .onboarding-form-group {
            margin-bottom: 16px;
        }

        .onboarding-label {
            display: block;
            font-size: 13px;
            color: var(--text-muted);
            margin-bottom: 6px;
        }

        .onboarding-input {
            width: 100%;
            padding: 12px 16px;
            background: var(--bg-main);
            border: 1px solid var(--border-medium);
            border-radius: 10px;
            color: var(--text-primary);
            font-size: 15px;
        }

        .onboarding-input:focus {
            outline: none;
            border-color: var(--cyan);
        }

        .ghin-lookup-result {
            background: var(--green-dim);
            border: 1px solid var(--green);
            border-radius: 10px;
            padding: 14px;
            margin-top: 12px;
        }

        .ghin-lookup-result.not-found {
            background: rgba(255,100,100,0.1);
            border-color: var(--red);
        }

        .lookup-name {
            font-weight: 600;
            margin-bottom: 4px;
        }

        .lookup-details {
            font-size: 13px;
            color: var(--text-secondary);
        }

        /* Client List Badge */
        .client-card-badge {
            position: absolute;
            top: 10px;
            right: 10px;
            background: var(--red);
            color: #fff;
            font-size: 10px;
            padding: 3px 8px;
            border-radius: 10px;
        }

        .client-card {
            position: relative;
        }

        /* ============================================
           MODALS
           ============================================ */
        .modal-overlay {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0,0,0,0.8);
            z-index: 3000;
            align-items: center;
            justify-content: center;
            padding: 20px;
        }

        .modal-overlay.active {
            display: flex;
        }

        .modal {
            background: var(--bg-card);
            border-radius: 16px;
            width: 100%;
            max-width: 420px;
            max-height: 90vh;
            overflow-y: auto;
        }

        .modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 20px;
            border-bottom: 1px solid var(--border-light);
        }

        .modal-title {
            font-size: 18px;
            font-weight: 700;
        }

        .modal-close {
            background: none;
            border: none;
            color: var(--text-muted);
            font-size: 24px;
            cursor: pointer;
            padding: 0;
            line-height: 1;
        }

        .modal-close:hover {
            color: var(--text-primary);
        }

        .modal-body {
            padding: 20px;
        }

        .modal-footer {
            padding: 16px 20px;
            border-top: 1px solid var(--border-light);
            display: flex;
            gap: 12px;
        }

        .modal-footer .btn {
            flex: 1;
        }

        /* Credit Breakdown */
        .credit-breakdown {
            background: var(--bg-main);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 16px;
        }

        .credit-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px 0;
            border-bottom: 1px solid var(--border-light);
        }

        .credit-row:last-child {
            border-bottom: none;
        }

        .credit-row.total {
            font-weight: 700;
            font-size: 16px;
            padding-top: 12px;
            margin-top: 4px;
            border-top: 2px solid var(--border-medium);
        }

        .credit-label {
            color: var(--text-secondary);
            font-size: 14px;
        }

        .credit-value {
            font-weight: 600;
            font-size: 14px;
        }

        .credit-value.cyan { color: var(--cyan); }
        .credit-value.green { color: var(--green); }
        .credit-value.yellow { color: var(--yellow); }
        .credit-value.purple { color: var(--purple); }

        /* Credit Pack */
        .credit-pack {
            background: var(--bg-main);
            border: 2px solid var(--border-medium);
            border-radius: 12px;
            padding: 16px;
            text-align: center;
            cursor: pointer;
            transition: all 0.2s;
            margin-bottom: 12px;
        }

        .credit-pack:hover {
            border-color: var(--cyan);
        }

        .credit-pack.selected {
            border-color: var(--cyan);
            background: var(--cyan-dim);
        }

        .credit-pack-amount {
            font-size: 24px;
            font-weight: 800;
            color: var(--cyan);
        }

        .credit-pack-price {
            font-size: 14px;
            color: var(--text-muted);
            margin-top: 4px;
        }

        .credit-packs-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 12px;
            margin-bottom: 16px;
        }

        /* Paywall Modal */
        .paywall-icon {
            font-size: 48px;
            text-align: center;
            margin-bottom: 16px;
        }

        .paywall-title {
            font-size: 20px;
            font-weight: 700;
            text-align: center;
            margin-bottom: 8px;
        }

        .paywall-desc {
            font-size: 14px;
            color: var(--text-muted);
            text-align: center;
            margin-bottom: 20px;
            line-height: 1.5;
        }

        .paywall-features {
            background: var(--bg-main);
            border-radius: 10px;
            padding: 16px;
            margin-bottom: 20px;
        }

        .paywall-feature {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 8px 0;
            font-size: 14px;
        }

        .paywall-feature-icon {
            color: var(--green);
        }

        /* Usage Indicator */
        .usage-indicator {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 12px;
            background: var(--bg-main);
            border-radius: 8px;
            margin-bottom: 16px;
        }

        .usage-bar {
            flex: 1;
            height: 8px;
            background: var(--border-medium);
            border-radius: 4px;
            overflow: hidden;
        }

        .usage-fill {
            height: 100%;
            background: var(--cyan);
            border-radius: 4px;
            transition: width 0.3s;
        }

        .usage-fill.warning {
            background: var(--yellow);
        }

        .usage-fill.critical {
            background: var(--red);
        }

        .usage-text {
            font-size: 12px;
            color: var(--text-muted);
            white-space: nowrap;
        }

        /* Factor Detail Modal */
        .factor-detail-header {
            display: flex;
            align-items: center;
            gap: 12px;
            margin-bottom: 20px;
        }

        .factor-detail-grade {
            width: 56px;
            height: 56px;
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 24px;
            font-weight: 700;
        }

        .factor-detail-grade.a { background: var(--green-dim); color: var(--green); }
        .factor-detail-grade.b { background: var(--cyan-dim); color: var(--cyan); }
        .factor-detail-grade.c { background: rgba(255,180,0,0.15); color: var(--yellow); }
        .factor-detail-grade.d { background: rgba(255,100,100,0.15); color: var(--red); }

        .factor-detail-info h3 {
            font-size: 18px;
            font-weight: 600;
            margin-bottom: 4px;
        }

        .factor-detail-info p {
            font-size: 13px;
            color: var(--text-muted);
        }

        .factor-detail-section {
            background: var(--bg-main);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 16px;
        }

        .factor-detail-section-title {
            font-size: 12px;
            font-weight: 600;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin-bottom: 12px;
        }

        .factor-club-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px 0;
            border-bottom: 1px solid var(--border-light);
        }

        .factor-club-row:last-child {
            border-bottom: none;
            padding-bottom: 0;
        }

        .factor-club-row:first-child {
            padding-top: 0;
        }

        .factor-club-name {
            font-size: 14px;
        }

        .factor-club-value {
            font-size: 13px;
            color: var(--text-muted);
        }

        .factor-club-value.issue {
            color: var(--red);
            font-weight: 500;
        }
        
        .factor-club-value.kickpoint-mismatch {
            color: #f5a623 !important;
            font-weight: 700 !important;
            background: rgba(245, 166, 35, 0.15);
            padding: 2px 6px;
            border-radius: 4px;
        }
        
        .factor-club-value.weight-mismatch {
            color: #f5a623 !important;
            font-weight: 700 !important;
            background: rgba(245, 166, 35, 0.15);
            padding: 2px 6px;
            border-radius: 4px;
        }
        
        /* Baseline-based weight suggestions (yellow to match favorite club) */
        .factor-club-value.weight-baseline {
            color: #ffd700 !important;
            font-weight: 700 !important;
            background: rgba(255, 215, 0, 0.15);
            padding: 2px 6px;
            border-radius: 4px;
        }
        
        /* Body-fit length suggestions (teal) */
        .factor-club-value.length-baseline {
            color: #00CED1 !important;
            font-weight: 700 !important;
            background: rgba(0, 206, 209, 0.15);
            padding: 2px 6px;
            border-radius: 4px;
        }
        
        /* Body fit baseline indicator */
        .bodyfit-indicator {
            background: rgba(0, 206, 209, 0.1);
            border: 1px solid rgba(0, 206, 209, 0.3);
            border-radius: 8px;
            padding: 10px 14px;
            margin-bottom: 12px;
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 13px;
        }
        .bodyfit-indicator .bodyfit-icon {
            font-size: 16px;
            color: #00CED1;
        }
        
        .factor-club-value.weight-minor {
            color: #e8c547 !important;
            font-weight: 600 !important;
            background: rgba(232, 197, 71, 0.1);
            padding: 2px 6px;
            border-radius: 4px;
        }
        
        .factor-club-value.weight-severe {
            color: #ff5252 !important;
            font-weight: 700 !important;
            background: rgba(255, 82, 82, 0.2);
            padding: 2px 6px;
            border-radius: 4px;
        }
        
        /* Overlap/Duplicate clubs - bright red warning */
        .factor-club-value.overlap {
            background: rgba(255, 82, 82, 0.25);
            color: var(--red);
            padding: 2px 8px;
            border-radius: 4px;
            font-weight: 600;
        }

        .factor-club-value.good {
            color: var(--green);
        }
        
        /* Estimated/Default values - yellow highlight with asterisk */
        .factor-club-value.estimated {
            background: rgba(255, 180, 0, 0.25);
            color: var(--yellow);
            padding: 2px 8px;
            border-radius: 4px;
            font-style: italic;
        }
        
        .factor-club-value.estimated::after {
            content: ' *';
            font-weight: bold;
        }
        
        .factor-estimated-footnote {
            margin-top: 16px;
            padding: 12px;
            background: rgba(255, 180, 0, 0.1);
            border-left: 3px solid var(--yellow);
            border-radius: 4px;
            font-size: 12px;
            color: var(--text-secondary);
        }
        
        .factor-estimated-footnote::before {
            content: '* ';
            color: var(--yellow);
            font-weight: bold;
        }
        
        /* Small edit button for factor modals */
        .btn-edit-small {
            background: transparent;
            border: 1px solid var(--cyan);
            color: var(--cyan);
            padding: 4px 10px;
            border-radius: 4px;
            font-size: 11px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .btn-edit-small:hover {
            background: var(--cyan);
            color: var(--bg-primary);
        }
        
        .btn-edit-small.active {
            background: var(--cyan);
            color: var(--bg-primary);
        }
        
        .btn-reset-small {
            background: transparent;
            border: 1px solid var(--yellow);
            color: var(--yellow);
            padding: 4px 10px;
            border-radius: 4px;
            font-size: 11px;
            cursor: pointer;
            transition: all 0.2s;
            margin-right: 6px;
        }
        
        .btn-reset-small:hover {
            background: var(--yellow);
            color: var(--bg-primary);
        }
        
        /* Length Edit Mode Styles */
        .length-edit-row {
            display: flex;
            align-items: center;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.1);
            gap: 10px;
        }
        
        .length-edit-row:last-child {
            border-bottom: none;
        }
        
        .length-edit-checkbox {
            width: 18px;
            height: 18px;
            accent-color: var(--cyan);
            cursor: pointer;
        }
        
        .length-edit-club {
            flex: 1;
            font-size: 13px;
            color: var(--text-primary);
        }
        
        .length-edit-current {
            font-size: 12px;
            color: var(--text-muted);
            min-width: 50px;
            text-align: right;
        }
        
        .length-edit-current.estimated {
            color: var(--yellow);
            font-style: italic;
        }
        
        .length-edit-current.estimated::after {
            content: '*';
            font-weight: bold;
        }
        
        .length-edit-select {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 12px;
            min-width: 80px;
        }
        
        .length-edit-select option {
            background: #ffffff;
            color: #000000;
        }
        
        .length-edit-select:focus {
            border-color: var(--cyan);
            outline: none;
        }
        
        .length-edit-actions {
            display: flex;
            gap: 8px;
            margin-top: 16px;
            padding-top: 12px;
            border-top: 1px solid rgba(255,255,255,0.1);
        }
        
        .length-edit-actions .btn {
            flex: 1;
            padding: 10px;
            font-size: 13px;
        }
        
        .length-select-all {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 0;
            margin-bottom: 8px;
            border-bottom: 1px solid rgba(255,255,255,0.15);
            font-size: 12px;
            color: var(--text-secondary);
        }
        
        /* Weight Edit Mode Styles */
        .weight-edit-row {
            display: flex;
            align-items: center;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.1);
            gap: 10px;
        }
        
        .weight-edit-row:last-child {
            border-bottom: none;
        }
        
        .weight-edit-club {
            flex: 1;
            font-size: 13px;
            color: var(--text-primary);
        }
        
        .weight-edit-current {
            font-size: 12px;
            color: var(--text-muted);
            min-width: 50px;
            text-align: right;
        }
        
        .weight-edit-current.estimated {
            color: var(--yellow);
            font-style: italic;
        }
        
        .weight-edit-current.estimated::after {
            content: '*';
            font-weight: bold;
        }
        
        .weight-edit-input {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 12px;
            width: 70px;
            text-align: center;
        }
        
        .weight-edit-input:focus {
            border-color: var(--cyan);
            outline: none;
        }
        
        .weight-edit-input::-webkit-inner-spin-button,
        .weight-edit-input::-webkit-outer-spin-button {
            opacity: 1;
        }
        
        .weight-edit-unit {
            font-size: 11px;
            color: var(--text-muted);
        }
        
        .weight-edit-reset-btn {
            background: transparent;
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-muted);
            padding: 2px 6px;
            border-radius: 4px;
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .weight-edit-reset-btn:hover:not(:disabled) {
            border-color: var(--yellow);
            color: var(--yellow);
        }
        
        .weight-edit-reset-btn:disabled {
            opacity: 0.3;
            cursor: not-allowed;
        }
        
        .weight-select-all {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.15);
            margin-bottom: 8px;
        }
        
        .weight-select-all label {
            font-size: 12px;
            color: var(--text-secondary);
        }
        
        .weight-edit-select {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 11px;
        }
        
        .weight-edit-checkbox {
            accent-color: var(--cyan);
        }
        
        /* Edit row highlighting for issues */
        .weight-edit-row.issue-severe,
        .length-edit-row.issue-severe,
        .lie-edit-row.issue-severe {
            background: rgba(255, 82, 82, 0.15);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .weight-edit-row.issue-warning,
        .length-edit-row.issue-warning,
        .lie-edit-row.issue-warning {
            background: rgba(255, 152, 0, 0.15);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .weight-edit-row.issue-minor,
        .length-edit-row.issue-minor,
        .lie-edit-row.issue-minor {
            background: rgba(255, 235, 59, 0.1);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .edit-warning-text {
            font-size: 10px;
            margin-left: 4px;
        }
        
        .edit-warning-text.severe {
            color: #ff5252;
        }
        
        .edit-warning-text.warning {
            color: #ff9800;
        }
        
        .edit-warning-text.minor {
            color: #ffeb3b;
        }
        
        .weight-edit-actions {
            display: flex;
            gap: 8px;
            margin-top: 16px;
            padding-top: 12px;
            border-top: 1px solid rgba(255,255,255,0.1);
        }
        
        .weight-edit-actions .btn {
            flex: 1;
            padding: 10px;
            font-size: 13px;
        }
        
        .weight-zone-header {
            margin-top: 12px;
            padding: 4px 0;
            font-size: 10px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
            border-bottom: 1px solid rgba(255,255,255,0.1);
        }
        
        .weight-zone-header:first-child {
            margin-top: 0;
        }
        
        /* Lie Edit Styles */
        .lie-edit-row {
            display: flex;
            align-items: center;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.1);
            gap: 10px;
        }
        
        .lie-edit-row:last-child {
            border-bottom: none;
        }
        
        .lie-edit-club {
            flex: 1;
            font-size: 13px;
            color: var(--text-primary);
        }
        
        .lie-edit-current {
            font-size: 12px;
            color: var(--text-muted);
            min-width: 50px;
            text-align: right;
        }
        
        .lie-edit-current.estimated {
            color: var(--yellow);
            font-style: italic;
        }
        
        .lie-edit-current.estimated::after {
            content: '*';
            font-weight: bold;
        }
        
        .lie-edit-input {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 12px;
            width: 70px;
            text-align: center;
        }
        
        .lie-edit-input:focus {
            border-color: var(--cyan);
            outline: none;
        }
        
        .lie-edit-input::-webkit-inner-spin-button,
        .lie-edit-input::-webkit-outer-spin-button {
            opacity: 1;
        }
        
        .lie-edit-unit {
            font-size: 11px;
            color: var(--text-muted);
        }
        
        .lie-edit-reset-btn {
            background: transparent;
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-muted);
            padding: 2px 6px;
            border-radius: 4px;
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .lie-edit-reset-btn:hover:not(:disabled) {
            border-color: var(--yellow);
            color: var(--yellow);
        }
        
        .lie-edit-reset-btn:disabled {
            opacity: 0.3;
            cursor: not-allowed;
        }
        
        .lie-select-all {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.15);
            margin-bottom: 8px;
        }
        
        .lie-select-all label {
            font-size: 12px;
            color: var(--text-secondary);
        }
        
        .lie-edit-select {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 11px;
        }
        
        .lie-edit-checkbox {
            accent-color: var(--cyan);
        }
        
        .lie-edit-actions {
            display: flex;
            gap: 8px;
            margin-top: 16px;
            padding-top: 12px;
            border-top: 1px solid rgba(255,255,255,0.1);
        }
        
        .lie-edit-actions .btn {
            flex: 1;
            padding: 10px;
            font-size: 13px;
        }
        
        .lie-zone-header {
            margin-top: 12px;
            padding: 4px 0;
            font-size: 10px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
            border-bottom: 1px solid rgba(255,255,255,0.1);
        }
        
        .lie-zone-header:first-child {
            margin-top: 0;
        }
        
        /* Loft Edit Styles */
        .loft-edit-row {
            display: flex;
            align-items: center;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.1);
            gap: 10px;
        }
        
        .loft-edit-row:last-child {
            border-bottom: none;
        }
        
        .loft-edit-row.issue-severe {
            background: rgba(255, 82, 82, 0.15);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .loft-edit-row.issue-warning {
            background: rgba(255, 152, 0, 0.15);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .loft-edit-club {
            flex: 1;
            font-size: 13px;
            color: var(--text-primary);
        }
        
        .loft-edit-current {
            font-size: 12px;
            color: var(--text-muted);
            min-width: 50px;
            text-align: right;
        }
        
        .loft-edit-current.estimated {
            color: var(--yellow);
            font-style: italic;
        }
        
        .loft-edit-current.estimated::after {
            content: '*';
            font-weight: bold;
        }
        
        .loft-edit-input {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 12px;
            width: 70px;
            text-align: center;
        }
        
        .loft-edit-input:focus {
            border-color: var(--cyan);
            outline: none;
        }
        
        .loft-edit-input::-webkit-inner-spin-button,
        .loft-edit-input::-webkit-outer-spin-button {
            opacity: 1;
        }
        
        .loft-edit-unit {
            font-size: 11px;
            color: var(--text-muted);
        }
        
        .loft-edit-reset-btn {
            background: transparent;
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-muted);
            padding: 2px 6px;
            border-radius: 4px;
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .loft-edit-reset-btn:hover:not(:disabled) {
            border-color: var(--yellow);
            color: var(--yellow);
        }
        
        .loft-edit-reset-btn:disabled {
            opacity: 0.3;
            cursor: not-allowed;
        }
        
        .loft-select-all {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.15);
            margin-bottom: 8px;
        }
        
        .loft-select-all label {
            font-size: 12px;
            color: var(--text-secondary);
        }
        
        .loft-edit-select {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 11px;
        }
        
        .loft-edit-checkbox {
            accent-color: var(--cyan);
        }
        
        .loft-edit-actions {
            display: flex;
            gap: 8px;
            margin-top: 16px;
            padding-top: 12px;
            border-top: 1px solid rgba(255,255,255,0.1);
        }
        
        .loft-edit-actions .btn {
            flex: 1;
            padding: 10px;
            font-size: 13px;
        }
        
        .loft-zone-header {
            margin-top: 12px;
            padding: 4px 0;
            font-size: 10px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
            border-bottom: 1px solid rgba(255,255,255,0.1);
        }
        
        .loft-zone-header:first-child {
            margin-top: 0;
        }
        
        .loft-gap-row {
            display: flex;
            align-items: center;
            padding: 4px 0 4px 24px;
            font-size: 11px;
            color: var(--text-muted);
        }
        
        .loft-gap-indicator {
            margin-right: 8px;
        }
        
        .loft-gap-value {
            margin-left: auto;
            font-weight: 500;
        }
        
        .loft-gap-value.good {
            color: var(--green);
        }
        
        .loft-gap-value.overlap {
            color: var(--red);
        }
        
        .loft-gap-value.issue {
            color: var(--yellow);
        }
        
        /* Flex Edit Styles */
        .flex-edit-row {
            display: flex;
            align-items: center;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.1);
            gap: 10px;
        }
        
        .flex-edit-row:last-child {
            border-bottom: none;
        }
        
        .flex-edit-club {
            flex: 1;
            font-size: 13px;
            color: var(--text-primary);
        }
        
        .flex-edit-current {
            font-size: 12px;
            color: var(--text-muted);
            min-width: 60px;
            text-align: right;
        }
        
        .flex-edit-current.estimated {
            color: var(--yellow);
            font-style: italic;
        }
        
        .flex-edit-current.estimated::after {
            content: '*';
            font-weight: bold;
        }
        
        .flex-edit-select {
            background: #2a2a3e;
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 6px 10px;
            border-radius: 4px;
            font-size: 12px;
            min-width: 90px;
        }
        
        .flex-edit-select:focus {
            border-color: var(--cyan);
            outline: none;
        }
        
        .flex-edit-select option {
            background: #2a2a3e;
            color: #ffffff;
            padding: 8px;
        }
        
        .flex-edit-reset-btn {
            background: transparent;
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-muted);
            padding: 2px 6px;
            border-radius: 4px;
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .flex-edit-reset-btn:hover:not(:disabled) {
            border-color: var(--yellow);
            color: var(--yellow);
        }
        
        .flex-edit-reset-btn:disabled {
            opacity: 0.3;
            cursor: not-allowed;
        }
        
        .flex-select-all {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 0;
            border-bottom: 1px solid rgba(255,255,255,0.15);
            margin-bottom: 8px;
        }
        
        .flex-select-all label {
            font-size: 12px;
            color: var(--text-secondary);
        }
        
        .flex-edit-checkbox {
            accent-color: var(--cyan);
        }
        
        .flex-edit-actions {
            display: flex;
            gap: 8px;
            margin-top: 16px;
            padding-top: 12px;
            border-top: 1px solid rgba(255,255,255,0.1);
        }
        
        .flex-edit-actions .btn {
            flex: 1;
            padding: 10px;
            font-size: 13px;
        }
        
        .flex-edit-row.issue-severe {
            background: rgba(255, 82, 82, 0.15);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .flex-edit-row.issue-warning {
            background: rgba(255, 152, 0, 0.15);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .flex-edit-row.issue-minor {
            background: rgba(255, 235, 59, 0.1);
            border-radius: 4px;
            margin: 2px -8px;
            padding: 8px !important;
        }
        
        .flex-zone-header {
            font-size: 10px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 1px;
            padding: 8px 0 4px 0;
            margin-top: 8px;
            border-bottom: 1px solid rgba(255,255,255,0.1);
        }
        
        .flex-zone-header:first-of-type {
            margin-top: 0;
        }
        
        /* Swing Speed Panel Styles */
        .swing-speed-panel {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.1);
            border-radius: 8px;
            padding: 12px;
            margin-bottom: 16px;
        }
        
        .swing-speed-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 8px;
        }
        
        .swing-speed-label {
            font-size: 11px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        
        .swing-speed-edit-btn {
            background: transparent;
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--cyan);
            padding: 4px 10px;
            border-radius: 4px;
            font-size: 11px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .swing-speed-edit-btn:hover {
            background: rgba(0, 212, 255, 0.1);
            border-color: var(--cyan);
        }
        
        .swing-speed-value {
            font-size: 24px;
            font-weight: 600;
            color: var(--text-primary);
        }
        
        .swing-speed-value .unit {
            font-size: 14px;
            font-weight: normal;
            color: var(--text-muted);
        }
        
        .swing-speed-value.not-set {
            font-size: 14px;
            color: var(--text-muted);
            font-style: italic;
        }
        
        .swing-speed-source {
            font-size: 11px;
            color: var(--text-muted);
            margin-top: 4px;
        }
        
        .swing-speed-recommendation {
            margin-top: 12px;
            padding-top: 12px;
            border-top: 1px solid rgba(255,255,255,0.1);
        }
        
        .swing-speed-rec-title {
            font-size: 11px;
            color: var(--text-muted);
            margin-bottom: 8px;
        }
        
        .swing-speed-rec-row {
            display: flex;
            justify-content: space-between;
            padding: 4px 0;
            font-size: 13px;
        }
        
        .swing-speed-rec-zone {
            color: var(--text-secondary);
        }
        
        .swing-speed-rec-value {
            color: var(--text-primary);
            font-weight: 500;
        }
        
        .swing-speed-rec-value.match {
            color: var(--green);
        }
        
        .swing-speed-rec-value.mismatch {
            color: var(--red);
        }
        
        /* Swing Speed Edit Mode */
        .swing-speed-edit-panel {
            background: var(--bg-secondary);
            border: 1px solid var(--cyan);
            border-radius: 8px;
            padding: 16px;
            margin-bottom: 16px;
        }
        
        .swing-speed-edit-title {
            font-size: 14px;
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: 16px;
        }
        
        .swing-speed-slider-container {
            margin-bottom: 16px;
        }
        
        .swing-speed-slider-value {
            text-align: center;
            font-size: 28px;
            font-weight: 600;
            color: var(--cyan);
            margin-bottom: 8px;
        }
        
        .swing-speed-slider {
            width: 100%;
            -webkit-appearance: none;
            height: 8px;
            border-radius: 4px;
            background: linear-gradient(to right, #4a9eff 0%, #00d4ff 50%, #ff6b6b 100%);
            outline: none;
            border: 1px solid rgba(255,255,255,0.2);
        }
        
        .swing-speed-slider::-webkit-slider-thumb {
            -webkit-appearance: none;
            width: 24px;
            height: 24px;
            border-radius: 50%;
            background: var(--cyan);
            cursor: pointer;
            border: 3px solid white;
            box-shadow: 0 2px 6px rgba(0,0,0,0.3);
        }
        
        .swing-speed-slider::-moz-range-thumb {
            width: 24px;
            height: 24px;
            border-radius: 50%;
            background: var(--cyan);
            cursor: pointer;
            border: 3px solid white;
            box-shadow: 0 2px 6px rgba(0,0,0,0.3);
        }
        
        .swing-speed-slider::-moz-range-track {
            height: 8px;
            border-radius: 4px;
            background: linear-gradient(to right, #4a9eff 0%, #00d4ff 50%, #ff6b6b 100%);
        }
        
        .swing-speed-slider-labels {
            display: flex;
            justify-content: space-between;
            font-size: 10px;
            color: var(--text-muted);
            margin-top: 4px;
        }
        
        .swing-speed-source-select {
            margin-bottom: 16px;
        }
        
        .swing-speed-source-label {
            font-size: 12px;
            color: var(--text-secondary);
            margin-bottom: 8px;
        }
        
        .swing-speed-source-options {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        
        .swing-speed-source-option {
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 12px;
            color: var(--text-secondary);
            cursor: pointer;
        }
        
        .swing-speed-source-option input {
            accent-color: var(--cyan);
        }
        
        .swing-speed-tip {
            background: rgba(0, 212, 255, 0.1);
            border-left: 3px solid var(--cyan);
            padding: 8px 12px;
            font-size: 11px;
            color: var(--text-secondary);
            margin-bottom: 16px;
        }
        
        .swing-speed-edit-actions {
            display: flex;
            gap: 8px;
        }
        
        .swing-speed-edit-actions .btn {
            flex: 1;
            padding: 10px;
            font-size: 13px;
        }
        
        /* Length Edit Input Style (number input instead of dropdown) */
        .length-edit-input {
            background: var(--bg-secondary);
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-primary);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 12px;
            width: 70px;
            text-align: center;
        }
        
        .length-edit-input:focus {
            border-color: var(--cyan);
            outline: none;
        }
        
        .length-edit-input::placeholder {
            color: #00CED1;
            opacity: 0.8;
            font-size: 10px;
        }
        
        .length-edit-input::-webkit-input-placeholder {
            color: #00CED1;
            opacity: 0.8;
            font-size: 10px;
        }
        
        .length-edit-input::-webkit-inner-spin-button,
        .length-edit-input::-webkit-outer-spin-button {
            opacity: 1;
        }
        
        .length-edit-unit {
            font-size: 11px;
            color: var(--text-muted);
        }
        
        .length-edit-reset-btn {
            background: transparent;
            border: 1px solid rgba(255,255,255,0.2);
            color: var(--text-muted);
            padding: 2px 6px;
            border-radius: 4px;
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .length-edit-reset-btn:hover:not(:disabled) {
            border-color: var(--yellow);
            color: var(--yellow);
        }
        
        .length-edit-reset-btn:disabled {
            opacity: 0.3;
            cursor: not-allowed;
        }
        
        /* Grade Explainer Section - Compact under grade */
        .grade-explainer {
            background: rgba(255, 82, 82, 0.08);
            border: 1px solid rgba(255, 82, 82, 0.2);
            border-radius: 8px;
            padding: 10px;
            margin-top: 12px;
            flex: 1;
        }
        
        .grade-explainer-header {
            display: flex;
            align-items: center;
            gap: 6px;
            margin-bottom: 8px;
        }
        
        .grade-explainer-header span {
            font-size: 12px;
        }
        
        .grade-explainer-header h4 {
            margin: 0;
            font-size: 12px;
            font-weight: 600;
            color: var(--text-primary);
        }
        
        .grade-explainer-summary {
            font-size: 11px;
            color: var(--text-secondary);
            margin-bottom: 8px;
            line-height: 1.3;
            display: none; /* Hide summary in compact mode */
        }
        
        .grade-explainer-impacts {
            display: flex;
            flex-direction: column;
            gap: 4px;
        }
        
        .grade-impact-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 6px 8px;
            background: rgba(0, 0, 0, 0.2);
            border-radius: 4px;
            border-left: 2px solid var(--red);
        }
        
        .grade-impact-item.fixable {
            border-left-color: var(--yellow);
        }
        
        .grade-impact-issue {
            font-size: 11px;
            color: var(--text-primary);
            flex: 1;
            line-height: 1.3;
        }
        
        .grade-impact-points {
            font-size: 11px;
            font-weight: 600;
            color: var(--red);
            white-space: nowrap;
            margin-left: 8px;
        }
        
        .grade-impact-fix {
            display: none; /* Hide fix text in compact mode */
        }
        
        /* AI Score Adjustment Display */
        .ai-score-comparison {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 8px 10px;
            background: rgba(0, 0, 0, 0.25);
            border-radius: 6px;
            margin-bottom: 10px;
            border: 1px solid rgba(255, 255, 255, 0.05);
        }
        
        .score-item {
            text-align: center;
        }
        
        .score-item .score-value {
            font-size: 18px;
            font-weight: 700;
            color: var(--text-primary);
        }
        
        .score-item .score-label {
            font-size: 9px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        
        .score-arrow {
            font-size: 16px;
            color: var(--text-muted);
        }
        
        .score-adjustment {
            text-align: center;
        }
        
        .score-adjustment .adj-value {
            font-size: 16px;
            font-weight: 700;
        }
        
        .score-adjustment .adj-value.positive {
            color: var(--green);
        }
        
        .score-adjustment .adj-value.negative {
            color: var(--red);
        }
        
        .score-adjustment .adj-value.neutral {
            color: var(--text-muted);
        }
        
        .score-adjustment .adj-label {
            font-size: 9px;
            color: var(--text-muted);
            text-transform: uppercase;
        }
        
        .ai-adjustment-summary {
            font-size: 12px;
            color: var(--text-secondary);
            line-height: 1.4;
            padding: 8px 10px;
            background: rgba(0, 0, 0, 0.15);
            border-radius: 4px;
            margin-bottom: 10px;
            border-left: 2px solid var(--primary);
        }
        
        .ai-factor-adjustments {
            display: flex;
            flex-wrap: wrap;
            gap: 4px;
            margin-bottom: 8px;
        }
        
        .ai-factor-adj-tag {
            font-size: 9px;
            padding: 2px 6px;
            border-radius: 3px;
            background: rgba(255, 255, 255, 0.05);
        }
        
        .ai-factor-adj-tag.positive {
            color: var(--green);
            border: 1px solid rgba(0, 200, 83, 0.3);
        }
        
        .ai-factor-adj-tag.negative {
            color: var(--red);
            border: 1px solid rgba(255, 82, 82, 0.3);
        }

        /* Grip Assessment Section - Bottom of Bag */
        .grip-assessment {
            background: rgba(255, 255, 255, 0.03);
            border: 1px solid var(--border-light);
            border-radius: 12px;
            padding: 16px;
        }
        
        .grip-assessment-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 12px;
        }
        
        .grip-assessment-header h4 {
            margin: 0;
            font-size: 14px;
            font-weight: 600;
            color: var(--text-primary);
        }
        
        .grip-status-badge {
            font-size: 11px;
            padding: 4px 8px;
            border-radius: 4px;
            font-weight: 500;
        }
        
        .grip-status-badge.good {
            background: var(--green-dim);
            color: var(--green);
        }
        
        .grip-status-badge.warning {
            background: var(--yellow-dim);
            color: var(--yellow);
        }
        
        .grip-status-badge.attention {
            background: var(--red-dim);
            color: var(--red);
        }
        
        .grip-assessment-content {
            display: flex;
            gap: 12px;
        }
        
        .grip-stat {
            text-align: center;
            padding: 12px 16px;
            background: rgba(0, 0, 0, 0.2);
            border-radius: 8px;
            flex: 1;
        }
        
        .grip-stat-value {
            font-size: 20px;
            font-weight: 700;
            color: var(--text-primary);
        }
        
        .grip-stat-label {
            font-size: 11px;
            color: var(--text-muted);
            margin-top: 4px;
        }
        
        .grip-cost-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 12px;
            background: rgba(255, 180, 0, 0.1);
            border-radius: 8px;
            margin-top: 12px;
        }
        
        .grip-cost-label {
            font-size: 13px;
            color: var(--text-secondary);
        }
        
        .grip-cost-value {
            font-size: 16px;
            font-weight: 600;
            color: var(--yellow);
        }
        
        .grip-add-data-btn {
            width: 100%;
            margin-top: 12px;
            padding: 10px;
            background: rgba(255, 255, 255, 0.05);
            border: 1px dashed var(--border-light);
            border-radius: 8px;
            color: var(--text-muted);
            font-size: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .grip-add-data-btn:hover {
            background: rgba(255, 255, 255, 0.1);
            color: var(--text-primary);
        }

        .factor-ai-analysis {
            background: linear-gradient(135deg, var(--cyan-dim) 0%, var(--purple-dim) 100%);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 16px;
            border: 1px solid var(--border-light);
        }

        .factor-ai-title {
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 14px;
            font-weight: 600;
            margin-bottom: 12px;
        }

        .factor-ai-content {
            font-size: 14px;
            color: var(--text-secondary);
            line-height: 1.6;
        }

        .factor-pro-insight {
            background: var(--purple-dim);
            border: 1px solid var(--purple);
            border-radius: 12px;
            padding: 16px;
            margin-bottom: 16px;
        }

        .factor-pro-insight-title {
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 13px;
            font-weight: 600;
            color: var(--purple);
            margin-bottom: 10px;
        }

        .factor-pro-insight-content {
            font-size: 13px;
            color: var(--text-secondary);
            line-height: 1.5;
        }

        .factor-upgrade-prompt {
            background: var(--bg-main);
            border: 2px dashed var(--border-medium);
            border-radius: 12px;
            padding: 20px;
            text-align: center;
        }

        .factor-upgrade-icon {
            font-size: 32px;
            margin-bottom: 10px;
        }

        .factor-upgrade-title {
            font-size: 15px;
            font-weight: 600;
            margin-bottom: 6px;
        }

        .factor-upgrade-desc {
            font-size: 13px;
            color: var(--text-muted);
            margin-bottom: 16px;
        }

        /* ============================================
           PATENT PENDING STYLES
           ============================================ */
        
        /* Header Patent Badge */
        .patent-badge {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            background: rgba(168, 85, 247, 0.15);
            border: 1px solid var(--purple);
            color: var(--purple);
            padding: 4px 10px;
            border-radius: 12px;
            font-size: 10px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            cursor: pointer;
            transition: all 0.2s ease;
        }
        .patent-badge:hover {
            background: rgba(168, 85, 247, 0.25);
            transform: scale(1.02);
        }
        
        /* Contextual Patent Tags */
        .patent-tag {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            color: var(--purple);
            font-size: 10px;
            font-weight: 500;
            opacity: 0.8;
            margin-left: 8px;
        }
        .patent-tag::before {
            content: "•";
            margin-right: 2px;
        }
        
        /* Favorite Club Baseline Badge */
        .baseline-badge {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            background: linear-gradient(135deg, rgba(255, 215, 0, 0.15), rgba(255, 165, 0, 0.1));
            border: 1px solid rgba(255, 215, 0, 0.4);
            border-radius: 12px;
            padding: 3px 8px;
            font-size: 10px;
            font-weight: 600;
            color: #ffd700;
            animation: baselinePulse 2s ease-in-out infinite;
        }
        .baseline-badge .baseline-star {
            font-size: 11px;
            color: #ffd700;
        }
        @keyframes baselinePulse {
            0%, 100% { box-shadow: 0 0 5px rgba(255, 215, 0, 0.3); }
            50% { box-shadow: 0 0 15px rgba(255, 215, 0, 0.5); }
        }
        
        /* Body Fit Baseline Badge */
        .bodyfit-badge {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            background: linear-gradient(135deg, rgba(0, 206, 209, 0.15), rgba(0, 139, 139, 0.1));
            border: 1px solid rgba(0, 206, 209, 0.4);
            border-radius: 12px;
            padding: 3px 8px;
            font-size: 10px;
            font-weight: 600;
            color: #00CED1;
            animation: bodyfitPulse 2s ease-in-out infinite;
        }
        .bodyfit-badge .bodyfit-icon {
            font-size: 11px;
        }
        @keyframes bodyfitPulse {
            0%, 100% { box-shadow: 0 0 5px rgba(0, 206, 209, 0.3); }
            50% { box-shadow: 0 0 15px rgba(0, 206, 209, 0.5); }
        }
        
        /* Clickable baseline badges */
        .clickable-badge {
            cursor: pointer;
            transition: transform 0.2s, box-shadow 0.2s;
        }
        .clickable-badge:hover {
            transform: scale(1.05);
        }
        .clickable-badge:active {
            transform: scale(0.98);
        }
        
        /* Baseline indicator for weight modal */
        .baseline-indicator {
            display: flex;
            align-items: center;
            gap: 6px;
            background: rgba(255, 215, 0, 0.1);
            border: 1px solid rgba(255, 215, 0, 0.3);
            border-radius: 8px;
            padding: 8px 12px;
            margin-bottom: 12px;
            font-size: 12px;
            color: #ffd700;
        }
        .baseline-indicator .baseline-star {
            font-size: 14px;
        }
        
        /* Persistent Footer */
        .persistent-footer {
            position: fixed;
            bottom: var(--fa-bar-height, 80px);
            left: 0;
            right: 0;
            background: rgba(13, 15, 20, 0.95);
            border-top: 1px solid var(--border-light);
            padding: 8px 16px;
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 16px;
            font-size: 11px;
            color: var(--text-muted);
            z-index: 1000;
            backdrop-filter: blur(10px);
        }
        .persistent-footer span {
            display: flex;
            align-items: center;
            gap: 4px;
        }
        .persistent-footer .purple {
            color: var(--purple);
        }
        
        /* Patent Modal */
        .patent-modal-content {
            max-width: 600px;
        }
        .patent-tagline {
            font-size: 20px;
            font-weight: 600;
            color: var(--cyan);
            text-align: center;
            margin-bottom: 20px;
        }
        .patent-stats {
            display: flex;
            justify-content: center;
            gap: 32px;
            margin-bottom: 24px;
            padding: 16px;
            background: var(--bg-input);
            border-radius: 12px;
        }
        .patent-stat {
            text-align: center;
        }
        .patent-stat-value {
            font-size: 24px;
            font-weight: 700;
            color: var(--purple);
        }
        .patent-stat-label {
            font-size: 11px;
            color: var(--text-muted);
            text-transform: uppercase;
        }
        .patent-table {
            width: 100%;
            border-collapse: collapse;
            margin-bottom: 20px;
        }
        .patent-table th {
            text-align: left;
            padding: 10px 12px;
            background: var(--bg-input);
            color: var(--text-secondary);
            font-size: 11px;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .patent-table td {
            padding: 12px;
            border-bottom: 1px solid var(--border-light);
            font-size: 13px;
        }
        .patent-table td:first-child {
            color: var(--text-primary);
        }
        .patent-table td:last-child {
            color: var(--purple);
            font-weight: 500;
        }
        .patent-table tr:last-child td {
            border-bottom: none;
        }
        .patent-footer {
            text-align: center;
            padding-top: 16px;
            border-top: 1px solid var(--border-light);
            color: var(--text-muted);
            font-size: 12px;
        }
        .patent-footer a {
            color: var(--cyan);
            text-decoration: none;
        }
        .patent-confidential {
            margin-top: 8px;
            font-size: 10px;
            color: var(--text-dim);
            font-style: italic;
        }

        /* Fit Assistant collapsed bar clearance — applied globally */
        :root {
            --fa-bar-height: 80px;
        }
        body {
            padding-bottom: var(--fa-bar-height);
        }
        .page.active {
            padding-bottom: var(--fa-bar-height);
        }

        /* Hide Fit Assistant during onboarding */
        body:not(.onboarding-complete) .fa-bar {
            display: none !important;
        }

        /* ==================== WELCOME STORYBOARD MODAL ==================== */
        #welcome-storyboard-modal {
            background: rgba(0,0,0,0.78);
            backdrop-filter: blur(14px);
        }
        #welcome-storyboard-modal .welcome-storyboard {
            background: var(--card-bg, #1A1F2E);
            border: 1px solid rgba(255,255,255,0.08);
            box-shadow: 0 24px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(0,212,255,0.06);
            animation: wsSlideUp 0.4s ease;
        }
        #welcome-storyboard-modal .btn-secondary {
            background: transparent;
            border: 1px solid var(--gray-dark);
            color: var(--text-primary);
        }
        @keyframes wsSlideUp {
            from { transform: translateY(30px); opacity: 0; }
            to { transform: translateY(0); opacity: 1; }
        }
        @keyframes wsGradePop {
            0% { transform: scale(0.3); opacity: 0; }
            100% { transform: scale(1); opacity: 1; }
        }

        /* Loading spinner animation */
        @keyframes spin {
            to { transform: rotate(360deg); }
        }

        /* ==================== PROFILE MODAL STYLES ==================== */
        
        .profile-modal {
            max-width: 500px;
        }
        
        .profile-header {
            display: flex;
            align-items: center;
            gap: 16px;
            margin-bottom: 20px;
        }
        
        .profile-picture-container {
            width: 80px;
            height: 80px;
            border-radius: 50%;
            overflow: hidden;
            position: relative;
            border: 3px solid var(--cyan);
            background: var(--bg-secondary);
            flex-shrink: 0;
        }
        
        .profile-picture-container img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
        
        .profile-picture-initials {
            width: 100%;
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 28px;
            font-weight: 700;
            color: var(--cyan);
            background: var(--bg-secondary);
        }
        
        .profile-picture-upload {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            background: rgba(0,0,0,0.7);
            padding: 4px;
            text-align: center;
            cursor: pointer;
            font-size: 10px;
            color: var(--text-muted);
            opacity: 0;
            transition: opacity 0.2s;
        }
        
        .profile-picture-container:hover .profile-picture-upload {
            opacity: 1;
        }
        
        .profile-name-section {
            flex: 1;
        }
        
        .profile-name-section h3 {
            margin: 0 0 4px 0;
            font-size: 18px;
        }
        
        .profile-name-section .email {
            color: var(--text-muted);
            font-size: 13px;
        }
        
        /* Profile Tabs */
        .profile-tabs {
            display: flex;
            gap: 4px;
            margin-bottom: 20px;
            border-bottom: 1px solid var(--border-light);
            padding-bottom: 0;
        }
        
        .profile-tab {
            padding: 10px 16px;
            background: transparent;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            font-size: 13px;
            font-weight: 500;
            border-bottom: 2px solid transparent;
            margin-bottom: -1px;
            transition: all 0.2s;
        }
        
        .profile-tab:hover {
            color: var(--text-primary);
        }
        
        .profile-tab.active {
            color: var(--cyan);
            border-bottom-color: var(--cyan);
        }
        
        .profile-tab-content {
            display: none;
        }
        
        .profile-tab-content.active {
            display: block;
        }
        
        /* Profile Form */
        .profile-form-row {
            display: flex;
            gap: 12px;
            margin-bottom: 16px;
        }
        
        .profile-form-group {
            flex: 1;
            min-width: 0;
        }
        
        .profile-form-group.full-width {
            flex: 100%;
        }
        
        .profile-form-label {
            display: block;
            font-size: 12px;
            color: var(--text-muted);
            margin-bottom: 6px;
            font-weight: 500;
        }
        
        .profile-form-input,
        .profile-form-select,
        .profile-form-textarea {
            width: 100%;
            background: var(--bg-secondary);
            border: 1px solid var(--border-light);
            border-radius: 8px;
            padding: 10px 12px;
            color: var(--text-primary);
            font-size: 14px;
            transition: border-color 0.2s;
        }
        
        .profile-form-input:focus,
        .profile-form-select:focus,
        .profile-form-textarea:focus {
            outline: none;
            border-color: var(--cyan);
        }
        
        .profile-form-input:disabled,
        .profile-form-select:disabled {
            opacity: 0.6;
            cursor: not-allowed;
        }
        
        .profile-form-select option {
            background: #1a1a2e;
            color: #ffffff;
        }
        
        .profile-form-input::placeholder {
            color: var(--text-dim);
        }
        
        .profile-form-textarea {
            min-height: 80px;
            resize: vertical;
        }
        
        .profile-form-helper {
            font-size: 11px;
            color: var(--text-dim);
            margin-top: 4px;
        }
        
        .profile-form-input-with-unit {
            display: flex;
            align-items: center;
            gap: 8px;
        }
        
        .profile-form-input-with-unit input {
            flex: 1;
        }
        
        .profile-form-unit {
            color: var(--text-muted);
            font-size: 13px;
            white-space: nowrap;
        }
        
        /* Profile Section Divider */
        .profile-section-title {
            font-size: 13px;
            font-weight: 600;
            color: var(--cyan);
            margin: 20px 0 12px 0;
            padding-bottom: 8px;
            border-bottom: 1px solid var(--border-light);
        }
        
        .profile-section-title:first-child {
            margin-top: 0;
        }
        
        /* Pro Notes Section */
        .pro-notes-section {
            background: rgba(0, 212, 255, 0.05);
            border: 1px solid rgba(0, 212, 255, 0.2);
            border-radius: 8px;
            padding: 16px;
            margin-top: 16px;
        }
        
        .pro-notes-header {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 12px;
            font-size: 13px;
            font-weight: 600;
            color: var(--cyan);
        }

/* ============================================
   TESTING TAB - BANNER CARDS
   ============================================ */

.banner-cards-container {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 16px;
    margin-bottom: 16px;
    scrollbar-width: thin;
}

.banner-cards-container::-webkit-scrollbar {
    height: 6px;
}

.banner-cards-container::-webkit-scrollbar-track {
    background: var(--bg-card);
    border-radius: 3px;
}

.banner-cards-container::-webkit-scrollbar-thumb {
    background: var(--border-medium);
    border-radius: 3px;
}

.banner-card {
    min-width: 200px;
    max-width: 220px;
    background: var(--bg-card);
    border: 2px solid var(--border-medium);
    border-radius: 12px;
    padding: 14px;
    cursor: pointer;
    transition: all 0.2s;
    position: relative;
    flex-shrink: 0;
}

.banner-card:hover {
    border-color: var(--cyan);
    transform: translateY(-2px);
}

.banner-card.winner-test {
    border-color: var(--green);
    background: var(--green-dim);
}

.banner-card.winner-yours {
    border-color: var(--cyan);
    background: var(--cyan-dim);
}

.banner-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.banner-card-type {
    font-size: 10px;
    text-transform: uppercase;
    color: var(--text-muted);
    font-weight: 600;
}

.banner-card-date {
    font-size: 10px;
    color: var(--text-muted);
}

.banner-card-title {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 4px;
}

.banner-card-subtitle {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

.banner-card-metrics {
    font-size: 12px;
    color: var(--green);
    font-weight: 600;
}

.banner-card-delete {
    position: absolute;
    top: 8px;
    right: 8px;
    background: none;
    border: none;
    font-size: 12px;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s;
}

.banner-card:hover .banner-card-delete {
    opacity: 0.7;
}

.banner-card-delete:hover {
    opacity: 1 !important;
}

.banner-cards-container .empty-state {
    width: 100%;
    text-align: center;
    padding: 24px;
    background: var(--bg-card);
    border-radius: 12px;
}

.empty-icon {
    font-size: 32px;
    margin-bottom: 8px;
}

.empty-text {
    font-weight: 600;
    margin-bottom: 4px;
}

.empty-hint {
    font-size: 12px;
    color: var(--text-muted);
}

/* Test Club Select Grid */
#test-club-select-grid {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.club-select-count {
    font-size: 11px;
    color: var(--text-muted);
    white-space: nowrap;
}
