/**
 * Career Intelligence Premium Upgrade - Elite+ v6.0
 * Enhanced visual effects, animations, and premium styling
 * V6.0: Position-aware visuals, glass morphism, micro-interactions
 */

/* ═══════════════════════════════════════════════════════════════════════════
   V6.0 CSS CUSTOM PROPERTIES
   ═══════════════════════════════════════════════════════════════════════════ */

.ci {
  --ci-gold: #f59e0b;
  --ci-gold-light: #fcd34d;
  --ci-purple: #8b5cf6;
  --ci-purple-light: #a78bfa;
  --ci-green: #22c55e;
  --ci-green-light: #4ade80;
  --ci-blue: #3b82f6;
  --ci-blue-light: #60a5fa;
  --ci-pink: #ec4899;
  --ci-cyan: #06b6d4;
  --ci-glass-bg: rgba(15, 15, 20, 0.7);
  --ci-glass-border: rgba(255, 255, 255, 0.08);
  --ci-glass-shine: rgba(255, 255, 255, 0.05);
  --ci-transition-smooth: cubic-bezier(0.4, 0, 0.2, 1);
  --ci-transition-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ═══════════════════════════════════════════════════════════════════════════
   ENHANCED AMBIENT BACKGROUND
   ═══════════════════════════════════════════════════════════════════════════ */

.ci {
  position: relative;
  background: linear-gradient(180deg, 
    rgba(10, 10, 15, 1) 0%, 
    rgba(15, 12, 25, 1) 30%,
    rgba(10, 15, 20, 1) 60%,
    rgba(10, 10, 15, 1) 100%
  );
}

.ci-ambient {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

/* Animated gradient mesh background */
.ci-ambient::before {
  content: '';
  position: absolute;
  inset: 0;
  background: 
    radial-gradient(ellipse 80% 50% at 20% 40%, rgba(245, 158, 11, 0.08) 0%, transparent 50%),
    radial-gradient(ellipse 60% 40% at 80% 20%, rgba(139, 92, 246, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse 50% 60% at 60% 80%, rgba(34, 197, 94, 0.05) 0%, transparent 50%);
  animation: ciAmbientPulse 15s ease-in-out infinite;
}

@keyframes ciAmbientPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.05); }
}

/* Floating particles */
.ci-ambient::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: 
    radial-gradient(1px 1px at 20% 30%, rgba(255, 255, 255, 0.3), transparent),
    radial-gradient(1px 1px at 40% 70%, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(1px 1px at 60% 20%, rgba(255, 255, 255, 0.25), transparent),
    radial-gradient(1px 1px at 80% 50%, rgba(255, 255, 255, 0.15), transparent),
    radial-gradient(1px 1px at 10% 80%, rgba(255, 255, 255, 0.2), transparent),
    radial-gradient(1px 1px at 90% 10%, rgba(255, 255, 255, 0.25), transparent);
  background-size: 100% 100%;
  animation: ciStarsTwinkle 10s ease-in-out infinite;
}

@keyframes ciStarsTwinkle {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

.ci-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.35;
  mix-blend-mode: screen;
}

.ci-orb-1 {
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(245, 158, 11, 0.4) 0%, rgba(217, 119, 6, 0.2) 40%, transparent 70%);
  top: -250px;
  right: -200px;
  animation: ciOrb1Float 25s ease-in-out infinite;
}

.ci-orb-2 {
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(139, 92, 246, 0.35) 0%, rgba(99, 102, 241, 0.15) 40%, transparent 70%);
  bottom: 10%;
  left: -200px;
  animation: ciOrb2Float 30s ease-in-out infinite;
}

.ci-orb-3 {
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(34, 197, 94, 0.3) 0%, rgba(22, 163, 74, 0.1) 40%, transparent 70%);
  top: 40%;
  right: 5%;
  animation: ciOrb3Float 20s ease-in-out infinite;
}

/* Add a 4th orb for more depth */
.ci-ambient .ci-orb-4 {
  position: absolute;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(236, 72, 153, 0.25) 0%, transparent 70%);
  top: 60%;
  left: 30%;
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.3;
  animation: ciOrb4Float 22s ease-in-out infinite;
}

@keyframes ciOrb1Float {
  0%, 100% { transform: translate(0, 0) scale(1) rotate(0deg); }
  25% { transform: translate(40px, -30px) scale(1.08) rotate(5deg); }
  50% { transform: translate(-30px, 40px) scale(0.95) rotate(-3deg); }
  75% { transform: translate(30px, 30px) scale(1.03) rotate(2deg); }
}

@keyframes ciOrb2Float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(50px, -40px) scale(1.1); }
  66% { transform: translate(-40px, 50px) scale(0.92); }
}

@keyframes ciOrb3Float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(-60px, -30px) scale(1.15); }
}

@keyframes ciOrb4Float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(50px, 50px) scale(0.9); }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PREMIUM HERO HEADER
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-hero {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 56px 24px 32px;
  margin-bottom: 0;
}

.ci-hero-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
  flex-wrap: wrap;
}

.ci-badge-premium {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 24px;
  background: linear-gradient(135deg, 
    rgba(245, 158, 11, 0.25) 0%, 
    rgba(217, 119, 6, 0.15) 50%,
    rgba(139, 92, 246, 0.15) 100%
  );
  border: 1px solid rgba(245, 158, 11, 0.5);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 2px;
  color: #fcd34d;
  margin-bottom: 24px;
  box-shadow: 
    0 0 30px rgba(245, 158, 11, 0.2),
    0 0 60px rgba(245, 158, 11, 0.1),
    inset 0 0 20px rgba(245, 158, 11, 0.1);
  animation: ciBadgeGlow 3s ease-in-out infinite;
}

@keyframes ciBadgeGlow {
  0%, 100% { 
    box-shadow: 
      0 0 30px rgba(245, 158, 11, 0.2),
      0 0 60px rgba(245, 158, 11, 0.1),
      inset 0 0 20px rgba(245, 158, 11, 0.1);
  }
  50% { 
    box-shadow: 
      0 0 40px rgba(245, 158, 11, 0.35),
      0 0 80px rgba(245, 158, 11, 0.2),
      inset 0 0 30px rgba(245, 158, 11, 0.15);
  }
}

.ci-crown {
  font-size: 18px;
  filter: drop-shadow(0 0 8px rgba(245, 158, 11, 0.6));
  animation: ciCrownFloat 2.5s ease-in-out infinite;
}

@keyframes ciCrownFloat {
  0%, 100% { transform: translateY(0) rotate(-5deg); }
  50% { transform: translateY(-4px) rotate(5deg); }
}

.ci-title {
  font-size: 48px;
  font-weight: 900;
  letter-spacing: -1.5px;
  background: linear-gradient(135deg, 
    #ffffff 0%, 
    #e4e4e7 30%,
    #fcd34d 60%,
    #f59e0b 80%,
    #ffffff 100%
  );
  background-size: 200% 200%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 16px;
  line-height: 1.1;
  animation: ciTitleShimmer 8s ease-in-out infinite;
  text-shadow: 0 0 60px rgba(245, 158, 11, 0.3);
}

@keyframes ciTitleShimmer {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

.ci-subtitle {
  font-size: 17px;
  color: rgba(161, 161, 170, 0.9);
  line-height: 1.7;
  max-width: 520px;
  margin: 0 auto;
}

/* Version badge in hero */
.ci-hero-version,
.ci-hero-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
  flex-wrap: wrap;
}

.ci-version-tag {
  display: inline-block;
  padding: 4px 12px;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.3), rgba(139, 92, 246, 0.2));
  border: 1px solid rgba(99, 102, 241, 0.5);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #a5b4fc;
}

.ci-version-features {
  font-size: 12px;
  color: rgba(161, 161, 170, 0.7);
  letter-spacing: 0.5px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TAB NAVIGATION SYSTEM (v7.0)
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-tabs-wrapper {
  position: relative;
  z-index: 2;
  margin: 0 auto 36px;
  max-width: 900px;
}

/* Scroll fade indicators */
.ci-tabs-wrapper::before,
.ci-tabs-wrapper::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 40px;
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.ci-tabs-wrapper::before {
  left: 0;
  background: linear-gradient(to right, rgba(15, 15, 20, 0.9), transparent);
  border-radius: 16px 0 0 16px;
}

.ci-tabs-wrapper::after {
  right: 0;
  background: linear-gradient(to left, rgba(15, 15, 20, 0.9), transparent);
  border-radius: 0 16px 16px 0;
}

.ci-tabs-wrapper.can-scroll-left::before {
  opacity: 1;
}

.ci-tabs-wrapper.can-scroll-right::after {
  opacity: 1;
}

.ci-tabs {
  position: relative;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px;
  background: rgba(15, 15, 20, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.ci-tabs::-webkit-scrollbar {
  display: none;
}

.ci-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 12px;
  color: rgba(161, 161, 170, 0.7);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.3px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
  position: relative;
  flex-shrink: 0;
}

.ci-tab svg {
  width: 16px;
  height: 16px;
  opacity: 0.6;
  transition: opacity 0.3s ease;
}

.ci-tab:hover {
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.05);
}

.ci-tab:hover svg {
  opacity: 0.9;
}

.ci-tab:focus-visible {
  outline: 2px solid rgba(245, 158, 11, 0.5);
  outline-offset: 2px;
}

.ci-tab-active,
.ci-tab-active:hover {
  color: #fcd34d;
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.15), rgba(217, 119, 6, 0.1));
  border: 1px solid rgba(245, 158, 11, 0.25);
  box-shadow: 0 0 20px rgba(245, 158, 11, 0.1);
}

.ci-tab-active svg {
  opacity: 1;
  color: #fcd34d;
}

/* Tab Panels */
.ci-tab-panel {
  display: none;
  animation: ciPanelFadeIn 0.4s ease;
}

.ci-tab-panel-active {
  display: block;
}

.ci-tab-panel > section {
  position: relative;
  z-index: 1;
  margin-bottom: 32px;
  padding: 28px;
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.7) 0%, rgba(15, 15, 18, 0.85) 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 22px;
}

.ci-tab-panel > section.ci-score-section {
  background: transparent;
  border: none;
  padding: 0;
}

/* Remove duplicate section backgrounds for sections that have their own cards */
.ci-tab-panel > section.ci-scout-section,
.ci-tab-panel > section.ci-gpt-section {
  background: transparent;
  border: none;
  padding: 0;
}

/* Ensure analytics sections get consistent card treatment */
.ci-tab-panel > section.ci-milestones-section,
.ci-tab-panel > section.ci-season-goals-section,
.ci-tab-panel > section.ci-competitive-section,
.ci-tab-panel > section.ci-heatmap-section,
.ci-tab-panel > section.ci-streaks-section {
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.6) 0%, rgba(15, 15, 18, 0.8) 100%);
}

@keyframes ciPanelFadeIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Mobile tab adjustments */
@media (max-width: 640px) {
  .ci-tabs-wrapper {
    margin-left: -8px;
    margin-right: -8px;
  }
  
  .ci-tabs {
    gap: 2px;
    padding: 4px;
    border-radius: 14px;
    justify-content: flex-start;
  }
  
  .ci-tab {
    padding: 8px 10px;
    font-size: 11px;
    gap: 4px;
  }
  
  .ci-tab span {
    display: none;
  }
  
  .ci-tab svg {
    width: 20px;
    height: 20px;
  }
}

@media (min-width: 641px) and (max-width: 900px) {
  .ci-tabs-wrapper {
    max-width: 100%;
  }
  
  .ci-tab {
    padding: 8px 12px;
    font-size: 12px;
  }
}

@media (min-width: 901px) and (max-width: 1100px) {
  .ci-tab {
    padding: 9px 14px;
    font-size: 12.5px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   SCORE CARD — v8.1 Clean
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-score-card {
  display: grid;
  grid-template-columns: minmax(200px, 280px) minmax(0, 1fr);
  gap: 32px;
  padding: 32px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(145deg, rgba(24, 24, 27, 0.85) 0%, rgba(15, 15, 18, 0.92) 100%);
  backdrop-filter: blur(20px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.ci-score-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.ci-score-visual {
  display: flex;
  justify-content: center;
}

.ci-score-ring-container {
  position: relative;
  width: 180px;
  height: 180px;
}

.ci-score-ring {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.ci-ring-bg {
  fill: none;
  stroke: rgba(255, 255, 255, 0.06);
  stroke-width: 10;
}

.ci-ring-progress {
  fill: none;
  stroke-width: 10;
  stroke-linecap: round;
  transition: stroke-dashoffset 1.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.ci-score-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}

.ci-score-value {
  font-size: 52px;
  font-weight: 800;
  background: linear-gradient(135deg, #fbbf24, #f59e0b, #d97706);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -2px;
  line-height: 1;
}

.ci-score-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(161, 161, 170, 0.7);
  text-transform: uppercase;
}

.ci-level-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 10px 16px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.ci-level-tier {
  font-size: 13px;
  font-weight: 700;
  color: var(--level-color, #fbbf24);
  letter-spacing: 0.5px;
}

.ci-level-divider {
  font-size: 14px;
  color: rgba(161, 161, 170, 0.4);
}

.ci-level-name {
  font-size: 13px;
  font-weight: 500;
  color: rgba(250, 250, 250, 0.7);
}

/* Score Content */
.ci-score-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: center;
}

.ci-score-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.ci-score-heading {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

.ci-score-summary {
  font-size: 14px;
  line-height: 1.7;
  color: rgba(161, 161, 170, 0.85);
  margin: 0;
}

/* KPI Grid */
.ci-score-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.ci-score-kpi {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 14px 10px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  transition: background 0.2s ease;
}

.ci-score-kpi:hover {
  background: rgba(255, 255, 255, 0.06);
}

.ci-kpi-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(251, 191, 36, 0.7);
}

.ci-score-kpi-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary, #fafafa);
  line-height: 1;
}

.ci-score-kpi-label {
  font-size: 11px;
  font-weight: 500;
  color: rgba(161, 161, 170, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PLAYER ARCHETYPE — v8.1 Clean
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-archetype {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(145deg, rgba(24, 24, 27, 0.85) 0%, rgba(15, 15, 18, 0.92) 100%);
  backdrop-filter: blur(20px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.ci-archetype-top-row {
  display: flex;
  align-items: center;
  gap: 16px;
}

.ci-archetype-icon {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

.ci-archetype-icon svg {
  width: 28px;
  height: 28px;
  opacity: 0.9;
}

.ci-archetype-title-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.ci-archetype-name {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.5px;
  line-height: 1.1;
}

.ci-archetype-badges {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ci-archetype-match {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid rgba(34, 197, 94, 0.3);
  background: rgba(34, 197, 94, 0.1);
  color: #4ade80;
  font-size: 11px;
  font-weight: 600;
}

.ci-archetype-desc {
  font-size: 14px;
  color: rgba(161, 161, 170, 0.85);
  line-height: 1.7;
  margin: 0;
}

/* Archetype Detail Sections */
.ci-archetype-traits,
.ci-archetype-secondary,
.ci-archetype-pros {
  padding: 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.ci-traits-label,
.ci-pro-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  color: rgba(161, 161, 170, 0.5);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px;
}

.ci-traits-list,
.ci-pro-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.ci-trait-tag {
  padding: 4px 10px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 500;
  color: rgba(250, 250, 250, 0.7);
  text-transform: capitalize;
}

.ci-archetype-pros .ci-pro-name {
  padding: 5px 14px;
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.15) 0%, rgba(99, 102, 241, 0.1) 100%);
  border: 1px solid rgba(139, 92, 246, 0.25);
  border-radius: 100px;
  font-size: 12px;
  font-weight: 600;
  color: #c4b5fd;
  transition: all 0.2s ease;
}

.ci-archetype-pros .ci-pro-name:hover {
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.25) 0%, rgba(99, 102, 241, 0.2) 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(139, 92, 246, 0.15);
}

/* STATS GRID PREMIUM */

.ci-stats-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 18px;
}

.ci-stat-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 28px 18px;
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.9) 0%, rgba(15, 15, 18, 0.95) 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 18px;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.ci-stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--stat-color, rgba(99, 102, 241, 0.5)), transparent);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.ci-stat-card:hover::before {
  opacity: 1;
}

.ci-stat-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255, 255, 255, 0.15);
  box-shadow: 
    0 16px 50px rgba(0, 0, 0, 0.5),
    0 0 40px var(--stat-glow, rgba(99, 102, 241, 0.1));
}

.ci-stat-matches { --stat-color: rgba(99, 102, 241, 0.6); --stat-glow: rgba(99, 102, 241, 0.15); }
.ci-stat-goals { --stat-color: rgba(34, 197, 94, 0.6); --stat-glow: rgba(34, 197, 94, 0.15); }
.ci-stat-assists { --stat-color: rgba(139, 92, 246, 0.6); --stat-glow: rgba(139, 92, 246, 0.15); }
.ci-stat-winrate { --stat-color: rgba(245, 158, 11, 0.6); --stat-glow: rgba(245, 158, 11, 0.15); }
.ci-stat-rating { --stat-color: rgba(236, 72, 153, 0.6); --stat-glow: rgba(236, 72, 153, 0.15); }
.ci-stat-training { --stat-color: rgba(6, 182, 212, 0.6); --stat-glow: rgba(6, 182, 212, 0.15); }

.ci-stat-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  transition: transform 0.3s ease;
}

.ci-stat-card:hover .ci-stat-icon {
  transform: scale(1.1);
}

.ci-stat-value {
  font-size: 32px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -1px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SECTION TITLES
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-section-title {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 22px;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 24px;
  letter-spacing: -0.3px;
}

.ci-section-title svg {
  color: rgba(161, 161, 170, 0.7);
  filter: drop-shadow(0 0 8px currentColor);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FORM SECTION PREMIUM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-form-section {
  position: relative;
  z-index: 1;
  margin-bottom: 36px;
  padding: 28px;
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.7) 0%, rgba(15, 15, 18, 0.85) 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 22px;
}

/* Inside tab panels, sections already have wrapping — slightly reduce padding */
.ci-tab-panel .ci-form-section,
.ci-tab-panel .ci-insights-section {
  background: transparent;
  border: none;
  padding: 0;
  margin-bottom: 0;
}

.ci-form-track {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 16px;
}

.ci-form-item {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  font-size: 20px;
  font-weight: 800;
  animation: ciFormPop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
  animation-delay: var(--delay);
  transition: all 0.3s ease;
}

.ci-form-item:hover {
  transform: scale(1.1) rotate(3deg);
}

.ci-form-empty {
  padding: 20px 40px;
  color: rgba(255, 255, 255, 0.4);
  font-size: 14px;
  text-align: center;
}

.ci-form-w {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  font-size: 20px;
  font-weight: 800;
  animation: ciFormPop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
  animation-delay: var(--delay);
  transition: all 0.3s ease;
}

.ci-form-item:hover {
  transform: scale(1.1) rotate(3deg);
}

.ci-form-w {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.25) 0%, rgba(22, 163, 74, 0.35) 100%);
  border: 1px solid rgba(34, 197, 94, 0.5);
  color: #4ade80;
  box-shadow: 0 0 20px rgba(34, 197, 94, 0.2);
}

.ci-form-d {
  background: linear-gradient(135deg, rgba(234, 179, 8, 0.25) 0%, rgba(202, 138, 4, 0.35) 100%);
  border: 1px solid rgba(234, 179, 8, 0.5);
  color: #facc15;
  box-shadow: 0 0 20px rgba(234, 179, 8, 0.2);
}

.ci-form-l {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.25) 0%, rgba(220, 38, 38, 0.35) 100%);
  border: 1px solid rgba(239, 68, 68, 0.5);
  color: #f87171;
  box-shadow: 0 0 20px rgba(239, 68, 68, 0.2);
}

/* ═══════════════════════════════════════════════════════════════════════════
   INSIGHTS CARDS PREMIUM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-insights-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.ci-insight-card {
  display: flex;
  gap: 18px;
  padding: 24px;
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.9) 0%, rgba(15, 15, 18, 0.95) 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-left: 4px solid var(--accent);
  border-radius: 18px;
  animation: ciSlideUp 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
  animation-delay: var(--delay);
  transition: all 0.4s ease;
  position: relative;
  overflow: hidden;
}

/* Subtle gradient overlay on hover */
.ci-insight-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--accent) 0%, transparent 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.ci-insight-card:hover::before {
  opacity: 0.03;
}

.ci-insight-card:hover {
  transform: translateX(8px);
  border-left-width: 6px;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
}

.ci-insight-icon {
  font-size: 36px;
  line-height: 1;
  filter: drop-shadow(0 0 10px var(--accent, rgba(99, 102, 241, 0.5)));
}

.ci-insight-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 8px;
}

.ci-insight-message {
  font-size: 14px;
  color: rgba(161, 161, 170, 0.9);
  line-height: 1.6;
}

.ci-insight-badge {
  align-self: flex-start;
  padding: 5px 12px;
  border-radius: 100px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SCOUT REPORT — v8.1 Premium
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-scout-card {
  background: linear-gradient(145deg, rgba(24, 24, 27, 0.85) 0%, rgba(15, 15, 18, 0.92) 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 20px;
  padding: 28px;
  backdrop-filter: blur(20px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: relative;
  overflow: hidden;
}

/* Confidential watermark */
.ci-scout-card::after {
  content: 'CONFIDENTIAL';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-30deg);
  font-size: 100px;
  font-weight: 900;
  color: rgba(255, 255, 255, 0.012);
  letter-spacing: 20px;
  white-space: nowrap;
  pointer-events: none;
}

/* Scout Header */
.ci-scout-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.ci-scout-id-group {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ci-scout-position {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 10px 20px;
  border-radius: 12px;
  color: white;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
}

.ci-scout-pos-label {
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 1px;
}

.ci-scout-pos-group {
  font-size: 9px;
  letter-spacing: 2px;
  opacity: 0.7;
  text-transform: uppercase;
}

.ci-scout-player-info {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ci-scout-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ci-scout-capacity {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.7);
}

.ci-scout-capacity strong {
  color: #fbbf24;
  font-size: 16px;
}

.ci-scout-divider {
  color: rgba(255, 255, 255, 0.2);
}

.ci-scout-archetype {
  font-size: 13px;
  color: #a78bfa;
  font-weight: 600;
}

.ci-scout-badges-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ci-scout-date {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.35);
}

.ci-scout-confidential {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: #ef4444;
  padding: 5px 12px;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  border-radius: 6px;
  flex-shrink: 0;
}

/* Radar Section */
.ci-scout-radar-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 16px 0;
}

.ci-scout-radar {
  display: flex;
  align-items: center;
  justify-content: center;
}

.ci-radar-svg {
  width: 240px;
  height: 240px;
}

.ci-scout-legend {
  display: flex;
  align-items: center;
  gap: 16px;
}

.ci-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
}

.ci-legend-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
}

.ci-legend-measured .ci-legend-dot { background: #22c55e; }
.ci-legend-inferred .ci-legend-dot { background: #f59e0b; }
.ci-legend-unmeasured .ci-legend-dot { background: rgba(255, 255, 255, 0.25); }

/* Ratings Grid - 3 columns */
.ci-scout-ratings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.ci-ratings-category {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 16px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.ci-ratings-title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255, 255, 255, 0.5);
  margin: 0 0 12px 0;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.ci-ratings-title svg {
  color: rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
}

.ci-ratings-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ci-rating-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ci-rating-name {
  flex: 0 0 80px;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.65);
  text-transform: capitalize;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ci-rating-bar {
  flex: 1;
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 100px;
  overflow: hidden;
  min-width: 40px;
}

.ci-rating-fill {
  height: 100%;
  width: var(--value, 0%);
  background: var(--color, #22c55e);
  border-radius: 100px;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.ci-rating-value {
  flex: 0 0 28px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.ci-rating-unmeasured .ci-rating-name {
  color: rgba(255, 255, 255, 0.3);
}

.ci-rating-unmeasured .ci-rating-value {
  color: rgba(255, 255, 255, 0.25);
}

/* Top Attributes */
.ci-scout-top-attrs {
  padding-top: 4px;
}

.ci-scout-top-attrs .ci-ratings-title {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 10px;
}

.ci-top-attrs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 10px;
}

.ci-top-attr {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 10px;
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.08) 0%, rgba(22, 163, 74, 0.12) 100%);
  border: 1px solid rgba(34, 197, 94, 0.15);
  border-radius: 12px;
  transition: all 0.2s ease;
}

.ci-top-attr:hover {
  transform: translateY(-2px);
  border-color: rgba(34, 197, 94, 0.3);
  box-shadow: 0 4px 16px rgba(34, 197, 94, 0.1);
}

.ci-top-attr-value {
  font-size: 22px;
  font-weight: 800;
  color: #4ade80;
}

.ci-top-attr-name {
  font-size: 10px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  text-transform: capitalize;
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════════════════════
   STREAKS SECTION PREMIUM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-streaks-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.ci-streak-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 28px 20px;
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.9) 0%, rgba(15, 15, 18, 0.95) 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 18px;
  transition: all 0.4s ease;
  position: relative;
  overflow: hidden;
}

.ci-streak-card::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, var(--streak-glow, rgba(245, 158, 11, 0.1)) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.ci-streak-card:hover::before {
  opacity: 1;
}

.ci-streak-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255, 255, 255, 0.15);
}

.ci-streak-wins { --streak-glow: rgba(245, 158, 11, 0.15); }
.ci-streak-unbeaten { --streak-glow: rgba(99, 102, 241, 0.15); }
.ci-streak-goals { --streak-glow: rgba(34, 197, 94, 0.15); }
.ci-streak-clean { --streak-glow: rgba(6, 182, 212, 0.15); }

.ci-streak-icon {
  font-size: 36px;
  filter: drop-shadow(0 0 12px currentColor);
}

.ci-streak-value {
  font-size: 42px;
  font-weight: 900;
  color: var(--text-primary);
  letter-spacing: -2px;
}

.ci-streak-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.ci-streak-best {
  font-size: 11px;
  color: rgba(161, 161, 170, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPT SECTION PREMIUM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-gpt-section {
  position: relative;
  z-index: 1;
  margin-bottom: 36px;
  padding: 36px;
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.95) 0%, rgba(15, 15, 18, 0.98) 100%);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 28px;
  box-shadow: 
    0 8px 40px rgba(0, 0, 0, 0.4),
    0 0 60px rgba(139, 92, 246, 0.05);
}

.ci-gpt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
}

.ci-gpt-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(99, 102, 241, 0.15) 100%);
  border: 1px solid rgba(139, 92, 246, 0.4);
  border-radius: 100px;
  font-size: 12px;
  font-weight: 700;
  color: #c4b5fd;
  box-shadow: 0 0 30px rgba(139, 92, 246, 0.15);
}

.ci-gpt-badge-icon {
  font-size: 18px;
  animation: ciRobotPulse 2s ease-in-out infinite;
}

@keyframes ciRobotPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}

.ci-gpt-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(139, 92, 246, 0.2);
  border-top-color: #a78bfa;
  border-radius: 50%;
  animation: ciGptSpin 1s linear infinite;
}

@keyframes ciGptSpin {
  to { transform: rotate(360deg); }
}

.ci-gpt-refresh-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.15) 0%, rgba(99, 102, 241, 0.1) 100%);
  border: 1px solid rgba(139, 92, 246, 0.3);
  border-radius: 12px;
  color: #c4b5fd;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  margin-top: 20px;
}

.ci-gpt-refresh-btn:hover {
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.25) 0%, rgba(99, 102, 241, 0.2) 100%);
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(139, 92, 246, 0.2);
}

/* ═══════════════════════════════════════════════════════════════════════════
   PLAYER PROFILE RADAR
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-radar-fallback,
.ci-player-radar-container {
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.95) 0%, rgba(15, 15, 18, 0.98) 100%);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 24px;
  padding: 32px;
  margin-bottom: 32px;
}

.ci-radar-header {
  margin-bottom: 24px;
}

.ci-radar-header h4 {
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 6px;
}

.ci-radar-subtitle {
  font-size: 14px;
  color: var(--text-muted);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FOOTER PREMIUM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-footer {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 48px 24px;
  margin-top: 48px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ci-footer p {
  font-size: 14px;
  color: rgba(161, 161, 170, 0.7);
  margin-bottom: 10px;
}

.ci-footer-disclaimer {
  font-size: 12px !important;
  color: rgba(161, 161, 170, 0.5) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MODEL BADGE (v5.2.1)
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-model-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  padding: 6px 12px;
  background: rgba(99, 102, 241, 0.15);
  border: 1px solid rgba(99, 102, 241, 0.3);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.ci-model-version {
  color: #a5b4fc;
}

.ci-model-mode {
  color: #fbbf24;
  padding: 2px 6px;
  background: rgba(251, 191, 36, 0.15);
  border-radius: 4px;
}

.ci-model-calibrated {
  color: #34d399;
  padding: 2px 6px;
  background: rgba(52, 211, 153, 0.15);
  border-radius: 4px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LOW-CONFIDENCE WARNINGS BANNER (v5.2.1)
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-warnings-banner {
  position: relative;
  z-index: 2;
  margin: 0 24px 24px;
  padding: 16px 20px;
  background: linear-gradient(135deg, rgba(251, 146, 60, 0.12), rgba(245, 158, 11, 0.08));
  border: 1px solid rgba(251, 146, 60, 0.3);
  border-radius: 12px;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.ci-warnings-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  font-size: 13px;
  font-weight: 600;
  color: #fbbf24;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.ci-warnings-header svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
}

.ci-warnings-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ci-warnings-list li {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.85);
  padding-left: 20px;
  position: relative;
}

.ci-warnings-list li::before {
  content: '⚠';
  position: absolute;
  left: 0;
  font-size: 11px;
}

.ci-improve-accuracy {
  border-top: 1px solid rgba(251, 146, 60, 0.2);
  padding-top: 12px;
}

.ci-improve-accuracy summary {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  list-style: none;
}

.ci-improve-accuracy summary::-webkit-details-marker {
  display: none;
}

.ci-improve-accuracy summary svg {
  width: 14px;
  height: 14px;
  transition: transform 0.2s ease;
}

.ci-improve-accuracy[open] summary svg {
  transform: rotate(180deg);
}

.ci-tips-list {
  list-style: none;
  padding: 0;
  margin: 12px 0 0 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ci-tips-list li {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.65);
  padding-left: 24px;
  position: relative;
  line-height: 1.5;
}

.ci-tips-list li::before {
  content: '💡';
  position: absolute;
  left: 0;
  font-size: 12px;
}

/* Footer stats row */
.ci-footer-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.ci-footer-stat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.7);
  transition: all 0.2s ease;
}

.ci-footer-stat:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.9);
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE ENHANCEMENTS
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 1200px) {
  .ci-stats-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .ci-top-attrs-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .ci-streaks-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 900px) {
  .ci-score-card {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 24px;
  }

  .ci-score-left {
    max-width: 300px;
    width: 100%;
    margin: 0 auto;
  }
  
  .ci-archetype {
    text-align: left;
  }
  
  .ci-archetype-top-row {
    flex-wrap: wrap;
  }

  .ci-score-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  
  .ci-insights-grid {
    grid-template-columns: 1fr;
  }
  
  .ci-scout-ratings-grid {
    grid-template-columns: 1fr;
  }
  
  .ci-scout-card {
    padding: 20px;
  }
  
  .ci-scout-header {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 640px) {
  .ci-title {
    font-size: 32px;
  }
  
  .ci-stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .ci-top-attrs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .ci-streaks-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .ci-score-card {
    padding: 20px;
  }

  .ci-score-kpi-grid {
    grid-template-columns: 1fr;
  }
  
  .ci-scout-id-group {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .ci-scout-ratings-grid {
    grid-template-columns: 1fr;
  }
  
  .ci-radar-svg {
    width: 200px;
    height: 200px;
  }
  
  .ci-rating-name {
    flex: 0 0 70px;
    font-size: 11px;
  }
  
  .ci-score-ring-container {
    width: 160px;
    height: 160px;
  }
  
  .ci-score-value {
    font-size: 44px;
  }

  .ci-archetype {
    padding: 18px;
  }

  .ci-archetype-name {
    font-size: 28px;
  }
}
/* ═══════════════════════════════════════════════════════════════════════════
   V2.0 ENHANCEMENTS - Confidence Badges & Explanations
   ═══════════════════════════════════════════════════════════════════════════ */

/* Confidence Badge */
.ci-confidence-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 9999px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Score Meta Section */
.ci-score-meta {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  margin-top: 4px;
}

/* Explanation Drawer */
.ci-explanation-drawer {
  width: 100%;
  max-width: none;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  overflow: hidden;
}

.ci-explanation-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  cursor: pointer;
  color: rgba(255, 255, 255, 0.7);
  font-size: 13px;
  font-weight: 500;
  transition: all 0.2s ease;
  list-style: none;
}

.ci-explanation-toggle::-webkit-details-marker {
  display: none;
}

.ci-explanation-toggle:hover {
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.02);
}

.ci-explanation-toggle svg {
  transition: transform 0.3s ease;
}

.ci-explanation-drawer[open] .ci-explanation-toggle svg {
  transform: rotate(180deg);
}

.ci-explanation-content {
  padding: 0 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ci-explanation-item {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
  padding-left: 12px;
  border-left: 2px solid rgba(245, 158, 11, 0.4);
  line-height: 1.5;
}

/* Archetype Enhancements */
.ci-archetype-header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 12px;
  margin-bottom: 0;
}

.ci-archetype-secondary {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  font-size: 13px;
}

.ci-secondary-label {
  color: rgba(255, 255, 255, 0.5);
}

.ci-secondary-name {
  color: rgba(255, 255, 255, 0.8);
  font-weight: 500;
}

.ci-secondary-sim {
  color: rgba(139, 92, 246, 0.8);
  font-size: 12px;
}

/* Trajectory Enhancements */
.ci-traj-range {
  display: block;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.5);
  margin-top: 4px;
}

.ci-development-velocity {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 10px;
  margin: 16px 0;
}

.ci-velocity-label {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.6);
}

.ci-velocity-value {
  font-size: 14px;
  font-weight: 600;
  font-family: 'JetBrains Mono', monospace;
}

.ci-velocity-value.positive {
  color: #22c55e;
}

.ci-velocity-value.negative {
  color: #ef4444;
}

.ci-velocity-value.neutral {
  color: rgba(255, 255, 255, 0.6);
}

.ci-trajectory-breakdown {
  margin-top: 16px;
}

/* Section title with confidence badge */
.ci-section-title {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.ci-section-title .ci-confidence-badge {
  font-size: 10px;
  padding: 3px 8px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MILESTONE PROGRESS SLIDERS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-milestone-progress {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 16px;
  animation: fadeInUp 0.4s ease calc(var(--delay, 0) + 0.2s) backwards;
}

.ci-mp-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.ci-mp-icon {
  font-size: 18px;
}

.ci-mp-title {
  flex: 1;
  font-weight: 600;
  color: var(--text-primary);
  font-size: 14px;
}

.ci-mp-count {
  font-size: 13px;
  font-weight: 700;
  color: #a78bfa;
}

.ci-mp-bar {
  height: 8px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 100px;
  overflow: hidden;
  margin-bottom: 8px;
}

.ci-mp-fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, #8b5cf6, #a78bfa);
  border-radius: 100px;
  transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 12px rgba(139, 92, 246, 0.5);
}

.ci-mp-desc {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
}

/* ═══════════════════════════════════════════════════════════════════════════
   SEASON GOALS SLIDERS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-season-goals-section {
  margin-bottom: 32px;
}

.ci-season-goals-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}

.ci-season-goal {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.1), rgba(139, 92, 246, 0.05));
  border: 1px solid rgba(99, 102, 241, 0.2);
  border-radius: 14px;
  padding: 18px;
  animation: fadeInUp 0.4s ease calc(var(--delay, 0) + 0.2s) backwards;
}

.ci-sg-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.ci-sg-icon {
  font-size: 20px;
}

.ci-sg-title {
  flex: 1;
  font-weight: 600;
  color: var(--text-primary);
  font-size: 14px;
}

.ci-sg-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.ci-sg-badge.on-track {
  background: rgba(34, 197, 94, 0.2);
  color: #4ade80;
}

.ci-sg-badge.behind {
  background: rgba(239, 68, 68, 0.2);
  color: #f87171;
}

.ci-sg-progress {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ci-sg-bar {
  flex: 1;
  height: 10px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 100px;
  overflow: hidden;
}

.ci-sg-fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--accent, #6366f1), color-mix(in srgb, var(--accent, #6366f1) 70%, white));
  border-radius: 100px;
  transition: width 1s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent, #6366f1) 50%, transparent);
}

.ci-sg-count {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  min-width: 60px;
  text-align: right;
}

/* ═══════════════════════════════════════════════════════════════════════════
   COMPETITIVE INDEX SLIDERS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-competitive-section {
  margin-bottom: 32px;
}

.ci-competitive-card {
  display: flex;
  gap: 32px;
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.1), rgba(245, 158, 11, 0.05));
  border: 1px solid rgba(251, 191, 36, 0.2);
  border-radius: 16px;
  padding: 24px;
}

.ci-ci-score-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 120px;
}

.ci-ci-score {
  font-size: 48px;
  font-weight: 900;
  color: #fbbf24;
  text-shadow: 0 0 30px rgba(251, 191, 36, 0.5);
  line-height: 1;
}

.ci-ci-rank {
  font-size: 14px;
  font-weight: 600;
  color: #fcd34d;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 8px;
}

.ci-ci-factors {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ci-ci-factor {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ci-ci-label {
  flex: 0 0 140px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.7);
}

.ci-ci-bar {
  flex: 1;
  height: 10px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 100px;
  overflow: hidden;
}

.ci-ci-fill {
  height: 100%;
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
  border-radius: 100px;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 12px rgba(251, 191, 36, 0.5);
}

.ci-ci-value {
  flex: 0 0 36px;
  font-size: 14px;
  font-weight: 700;
  color: #fbbf24;
  text-align: right;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MILESTONES SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-milestones-section {
  margin-bottom: 32px;
}

.ci-milestones-subtitle {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 12px;
}

.ci-milestones-achieved {
  margin-bottom: 20px;
}

.ci-milestones-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}

.ci-milestone {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  animation: fadeInUp 0.3s ease calc(var(--delay, 0) + 0.1s) backwards;
  transition: all 0.3s ease;
}

.ci-milestone:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.05);
}

.ci-milestone-achieved {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.1), rgba(22, 163, 74, 0.05));
  border-color: rgba(34, 197, 94, 0.25);
}

.ci-milestone-icon {
  font-size: 18px;
}

.ci-milestone-title {
  flex: 1;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
}

.ci-milestone-check {
  font-size: 14px;
  color: #4ade80;
  font-weight: 700;
}

.ci-milestones-upcoming {
  margin-top: 16px;
}

.ci-milestones-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PERFORMANCE HEATMAP SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-heatmap-section {
  margin-bottom: 32px;
}

.ci-heatmap-card {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.08), rgba(139, 92, 246, 0.04));
  border: 1px solid rgba(99, 102, 241, 0.15);
  border-radius: 16px;
  padding: 24px;
}

.ci-heatmap-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
  margin-bottom: 20px;
}

.ci-heatmap-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 14px 8px;
  background: rgba(255, 255, 255, calc(0.02 + var(--intensity, 0) * 0.002));
  border: 1px solid rgba(99, 102, 241, calc(0.1 + var(--intensity, 0) * 0.005));
  border-radius: 10px;
  transition: all 0.3s ease;
}

.ci-heatmap-day:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(99, 102, 241, 0.15);
}

.ci-hd-name {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}

.ci-hd-value {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
}

.ci-hd-count {
  font-size: 10px;
  color: rgba(255, 255, 255, 0.4);
  margin-top: 4px;
}

.ci-heatmap-insights {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
}

.ci-hm-insight {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 8px;
}

.ci-hm-label {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.ci-hm-value {
  font-size: 15px;
  font-weight: 700;
  color: #a78bfa;
}

/* Responsive adjustments */
@media (max-width: 640px) {
  .ci-competitive-card {
    flex-direction: column;
    gap: 20px;
  }
  
  .ci-ci-score-container {
    flex-direction: row;
    justify-content: flex-start;
    gap: 16px;
  }
  
  .ci-ci-label {
    flex: 0 0 100px;
    font-size: 12px;
  }
  
  .ci-heatmap-days {
    grid-template-columns: repeat(4, 1fr);
  }
  
  .ci-milestones-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   V6.0 ENHANCED VISUAL UPGRADES
   ═══════════════════════════════════════════════════════════════════════════ */

/* Position Badge - V6.0 Position-Aware */
.ci-position-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.2), rgba(139, 92, 246, 0.15));
  border: 1px solid rgba(99, 102, 241, 0.4);
  border-radius: 100px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #a5b4fc;
  box-shadow: 0 0 20px rgba(99, 102, 241, 0.15);
}

.ci-position-badge .pos-icon {
  font-size: 16px;
}

/* Enhanced Glass Card Effect */
.ci-glass-card {
  background: linear-gradient(135deg, 
    rgba(20, 20, 25, 0.8) 0%, 
    rgba(15, 15, 20, 0.9) 100%
  );
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 20px;
  box-shadow: 
    0 8px 32px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 1px rgba(255, 255, 255, 0.02);
  position: relative;
  overflow: hidden;
}

.ci-glass-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, 
    transparent 0%, 
    rgba(255, 255, 255, 0.1) 50%, 
    transparent 100%
  );
}

/* Shimmer Effect on Cards */
.ci-shimmer {
  position: relative;
  overflow: hidden;
}

.ci-shimmer::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.03) 50%,
    transparent 100%
  );
  animation: ciShimmerSlide 3s ease-in-out infinite;
}

@keyframes ciShimmerSlide {
  0% { left: -100%; }
  50%, 100% { left: 100%; }
}

/* Pulse Ring Animation */
.ci-pulse-ring {
  position: relative;
}

.ci-pulse-ring::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid var(--ring-color, rgba(245, 158, 11, 0.5));
  animation: ciPulseRing 2s ease-out infinite;
}

@keyframes ciPulseRing {
  0% { transform: scale(1); opacity: 1; }
  100% { transform: scale(1.5); opacity: 0; }
}

/* Enhanced Score Display */
.ci-mega-score {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.ci-mega-score-value {
  font-size: 96px;
  font-weight: 900;
  letter-spacing: -6px;
  background: linear-gradient(135deg, 
    #fcd34d 0%, 
    #f59e0b 30%,
    #d97706 60%,
    #fcd34d 100%
  );
  background-size: 200% 200%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: ciScoreShine 4s ease-in-out infinite;
  filter: drop-shadow(0 0 40px rgba(245, 158, 11, 0.3));
  line-height: 1;
}

@keyframes ciScoreShine {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* Floating Badge Animation */
.ci-floating-badge {
  animation: ciFloatBadge 3s ease-in-out infinite;
}

@keyframes ciFloatBadge {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50% { transform: translateY(-8px) rotate(2deg); }
}

/* Glow Dot Indicator */
.ci-glow-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--dot-color, #22c55e);
  box-shadow: 
    0 0 8px var(--dot-color, #22c55e),
    0 0 16px var(--dot-color, #22c55e),
    0 0 24px color-mix(in srgb, var(--dot-color, #22c55e) 50%, transparent);
  animation: ciDotPulse 2s ease-in-out infinite;
}

@keyframes ciDotPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.2); }
}

/* Enhanced Progress Bars */
.ci-progress-glow {
  position: relative;
  height: 10px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 100px;
  overflow: hidden;
}

.ci-progress-glow-fill {
  height: 100%;
  border-radius: 100px;
  background: linear-gradient(90deg, var(--progress-color, #6366f1), color-mix(in srgb, var(--progress-color, #6366f1) 80%, white));
  box-shadow: 
    0 0 20px var(--progress-color, #6366f1),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
  transition: width 1s var(--ci-transition-smooth);
  position: relative;
}

.ci-progress-glow-fill::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 50%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.3), transparent);
  border-radius: 100px 100px 0 0;
}

/* Neon Text Effect */
.ci-neon-text {
  color: var(--neon-color, #c084fc);
  text-shadow: 
    0 0 5px var(--neon-color, #c084fc),
    0 0 10px var(--neon-color, #c084fc),
    0 0 20px color-mix(in srgb, var(--neon-color, #c084fc) 70%, transparent),
    0 0 40px color-mix(in srgb, var(--neon-color, #c084fc) 50%, transparent);
}

/* Card Hover Lift Effect */
.ci-lift-hover {
  transition: all 0.4s var(--ci-transition-smooth);
}

.ci-lift-hover:hover {
  transform: translateY(-8px);
  box-shadow: 
    0 20px 60px rgba(0, 0, 0, 0.4),
    0 0 40px rgba(99, 102, 241, 0.1);
}

/* Animated Border Gradient */
.ci-animated-border {
  position: relative;
  background: var(--ci-glass-bg);
  border-radius: 16px;
  z-index: 1;
}

.ci-animated-border::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 18px;
  background: linear-gradient(
    var(--border-angle, 0deg),
    rgba(245, 158, 11, 0.5),
    rgba(139, 92, 246, 0.5),
    rgba(34, 197, 94, 0.5),
    rgba(245, 158, 11, 0.5)
  );
  z-index: -1;
  animation: ciRotateBorder 4s linear infinite;
}

.ci-animated-border::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 16px;
  background: inherit;
  z-index: -1;
}

@keyframes ciRotateBorder {
  0% { --border-angle: 0deg; }
  100% { --border-angle: 360deg; }
}

@property --border-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

/* Micro-interaction: Button Press */
.ci-press-effect {
  transition: transform 0.15s ease;
}

.ci-press-effect:active {
  transform: scale(0.96);
}

/* Score Tier Badges */
.ci-tier-elite {
  --tier-color: #c084fc;
  --tier-glow: rgba(192, 132, 252, 0.4);
}

.ci-tier-pro {
  --tier-color: #34d399;
  --tier-glow: rgba(52, 211, 153, 0.4);
}

.ci-tier-semipro {
  --tier-color: #fbbf24;
  --tier-glow: rgba(251, 191, 36, 0.4);
}

.ci-tier-amateur {
  --tier-color: #60a5fa;
  --tier-glow: rgba(96, 165, 250, 0.4);
}

.ci-tier-developing {
  --tier-color: #a78bfa;
  --tier-glow: rgba(167, 139, 250, 0.4);
}

.ci-tier-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: linear-gradient(135deg, 
    color-mix(in srgb, var(--tier-color) 20%, transparent),
    color-mix(in srgb, var(--tier-color) 10%, transparent)
  );
  border: 1px solid color-mix(in srgb, var(--tier-color) 50%, transparent);
  border-radius: 100px;
  color: var(--tier-color);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  box-shadow: 0 0 20px var(--tier-glow);
}

/* Gradient Dividers */
.ci-divider {
  height: 1px;
  background: linear-gradient(90deg, 
    transparent 0%,
    rgba(255, 255, 255, 0.1) 20%,
    rgba(255, 255, 255, 0.15) 50%,
    rgba(255, 255, 255, 0.1) 80%,
    transparent 100%
  );
  margin: 24px 0;
}

/* Metric Pill */
.ci-metric-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 100px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.8);
  transition: all 0.2s ease;
}

.ci-metric-pill:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.12);
}

.ci-metric-pill .value {
  font-weight: 700;
  color: var(--metric-color, #a5b4fc);
}

/* Stagger Animation Delays */
.ci-stagger-1 { --delay: 0.05s; }
.ci-stagger-2 { --delay: 0.1s; }
.ci-stagger-3 { --delay: 0.15s; }
.ci-stagger-4 { --delay: 0.2s; }
.ci-stagger-5 { --delay: 0.25s; }
.ci-stagger-6 { --delay: 0.3s; }
.ci-stagger-7 { --delay: 0.35s; }
.ci-stagger-8 { --delay: 0.4s; }

/* Fade In Up Animation */
@keyframes ciFadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.ci-fade-in-up {
  animation: ciFadeInUp 0.5s var(--ci-transition-smooth) calc(var(--delay, 0s)) backwards;
}

/* Scale In Animation */
@keyframes ciScaleIn {
  from {
    opacity: 0;
    transform: scale(0.9);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.ci-scale-in {
  animation: ciScaleIn 0.4s var(--ci-transition-bounce) calc(var(--delay, 0s)) backwards;
}

/* Skeleton Loading */
.ci-skeleton {
  background: linear-gradient(90deg,
    rgba(255, 255, 255, 0.04) 0%,
    rgba(255, 255, 255, 0.08) 50%,
    rgba(255, 255, 255, 0.04) 100%
  );
  background-size: 200% 100%;
  animation: ciSkeletonPulse 1.5s ease-in-out infinite;
  border-radius: 8px;
}

@keyframes ciSkeletonPulse {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   V6.0 RADAR CHART ENHANCEMENTS
   ═══════════════════════════════════════════════════════════════════════════ */

.crg-position-aware {
  position: relative;
}

.crg-position-label {
  position: absolute;
  top: 12px;
  right: 12px;
  padding: 4px 10px;
  background: rgba(99, 102, 241, 0.15);
  border: 1px solid rgba(99, 102, 241, 0.3);
  border-radius: 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #a5b4fc;
}

/* Enhanced Radar Point Hover */
.crg-point {
  transition: all 0.2s ease;
  cursor: pointer;
}

.crg-point:hover {
  r: 8;
  filter: drop-shadow(0 0 12px currentColor);
}

/* Radar Tooltip */
.crg-tooltip {
  position: absolute;
  padding: 8px 12px;
  background: rgba(15, 15, 20, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  font-size: 12px;
  color: #fff;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: all 0.2s ease;
  z-index: 100;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.crg-tooltip.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ═══════════════════════════════════════════════════════════════════════════
   V6.0 BUG FIXES
   ═══════════════════════════════════════════════════════════════════════════ */

/* Fix z-index stacking in CI sections */
.ci section {
  position: relative;
  z-index: 1;
}

/* Fix overflow issues on mobile */
.ci-score-card,
.ci-archetype,
.ci-scout-card {
  overflow: visible;
}

/* Ensure proper text contrast */
.ci-subtitle,
.ci-section-subtitle {
  color: rgba(161, 161, 170, 0.85);
}

/* Fix radar chart clipping */
.ci-radar-glass .crg-svg,
.ci-player-radar-container svg {
  overflow: visible;
}

/* Fix glass card backdrop on Safari */
@supports not (backdrop-filter: blur(20px)) {
  .ci-glass-card {
    background: rgba(15, 15, 20, 0.95);
  }
}

/* Fix animation jank on low-end devices */
@media (prefers-reduced-motion: reduce) {
  .ci-shimmer::after,
  .ci-animated-border::before,
  .ci-pulse-ring::after,
  .ci-glow-dot,
  .ci-floating-badge {
    animation: none;
  }
}

/* Responsive text sizing fix */
@media (max-width: 480px) {
  .ci-mega-score-value {
    font-size: 64px;
    letter-spacing: -4px;
  }
  
  .ci-title {
    font-size: 28px;
  }
  
  .ci-archetype-name {
    font-size: 22px;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — PREMIUM SECTION CARD SYSTEM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-premium-section {
  position: relative;
  background: rgba(15, 15, 20, 0.65);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  margin-bottom: 24px;
  overflow: hidden;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.ci-premium-section:hover {
  border-color: rgba(99, 102, 241, 0.18);
  box-shadow: 0 0 30px rgba(99, 102, 241, 0.06);
}
.ci-premium-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px 14px;
  cursor: pointer;
  user-select: none;
}
.ci-premium-section-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text-primary, #fafafa);
  display: flex;
  align-items: center;
  gap: 10px;
}
.ci-premium-section-subtitle {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 2px;
}
.ci-premium-section-body {
  padding: 0 22px 22px;
}
.ci-premium-section.collapsed .ci-premium-section-body {
  display: none;
}
.ci-premium-section .ci-chevron {
  width: 20px;
  height: 20px;
  color: var(--color-text-secondary, #a1a1aa);
  transition: transform 0.25s ease;
}
.ci-premium-section.collapsed .ci-chevron {
  transform: rotate(-90deg);
}

/* PREMIUM Badge */
.ci-premium-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  background: linear-gradient(135deg, rgba(255, 215, 0, 0.15), rgba(245, 158, 11, 0.10));
  color: #ffd700;
  border: 1px solid rgba(255, 215, 0, 0.20);
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — TAB SYSTEM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-tab-bar {
  display: flex;
  gap: 2px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 10px;
  padding: 3px;
  margin-bottom: 16px;
  overflow-x: auto;
  scrollbar-width: none;
}
.ci-tab-bar::-webkit-scrollbar { display: none; }

.ci-tab-btn {
  flex: 1;
  min-width: 80px;
  padding: 8px 14px;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--color-text-secondary, #a1a1aa);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.ci-tab-btn:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--color-text-primary, #fafafa);
}
.ci-tab-btn.active {
  background: rgba(99, 102, 241, 0.12);
  color: var(--color-accent, #6366f1);
  font-weight: 600;
}
.ci-tab-panel {
  display: none;
}
.ci-tab-panel.active {
  display: block;
  animation: ciTabFadeIn 0.25s ease;
}
@keyframes ciTabFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — STAT CARDS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-stat-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  transition: border-color 0.2s ease;
  min-width: 90px;
}
.ci-stat-card:hover {
  border-color: rgba(99, 102, 241, 0.15);
}
.ci-stat-card-value {
  font-size: 22px;
  font-weight: 800;
  font-family: var(--font-mono, monospace);
  color: var(--color-text-primary, #fafafa);
  line-height: 1.1;
}
.ci-stat-card-label {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.ci-stat-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.ci-stat-row > * {
  flex: 1;
  min-width: 80px;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — GRADE BADGES
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-grade-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-family: var(--font-mono, monospace);
  border-radius: 8px;
  text-shadow: 0 0 12px currentColor;
}
.ci-grade-badge.small {
  width: 28px;
  height: 28px;
  font-size: 13px;
}
.ci-grade-badge.medium {
  width: 40px;
  height: 40px;
  font-size: 18px;
}
.ci-grade-badge.large {
  width: 56px;
  height: 56px;
  font-size: 26px;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — PRO COMPARISON SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-pro-match-card {
  display: flex;
  gap: 16px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  margin-bottom: 14px;
  transition: border-color 0.2s;
}
.ci-pro-match-card:hover {
  border-color: rgba(99, 102, 241, 0.15);
}
.ci-pro-avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.10);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.ci-pro-info {
  flex: 1;
  min-width: 0;
}
.ci-pro-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text-primary, #fafafa);
}
.ci-pro-meta {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-pro-similarity-bar {
  margin-top: 8px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}
.ci-pro-similarity-fill {
  height: 100%;
  border-radius: 2px;
  background: var(--color-accent, #6366f1);
  transition: width 0.6s ease;
}
.ci-stat-delta {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  font-weight: 600;
  padding: 1px 5px;
  border-radius: 4px;
}
.ci-stat-delta.positive {
  color: var(--color-success, #22c55e);
  background: rgba(34, 197, 94, 0.10);
}
.ci-stat-delta.negative {
  color: var(--color-error, #ef4444);
  background: rgba(239, 68, 68, 0.10);
}
.ci-stat-delta.neutral {
  color: var(--color-text-secondary, #a1a1aa);
  background: rgba(255, 255, 255, 0.05);
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — DUAL RADAR CHART
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-dual-radar-container {
  display: flex;
  justify-content: center;
  padding: 10px 0;
  margin-bottom: 14px;
}
.ci-dual-radar-container svg {
  max-width: 100%;
  height: auto;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ACHIEVEMENT SHELF
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-achievement-shelf {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding: 8px 2px 12px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}
.ci-achievement-shelf::-webkit-scrollbar {
  height: 4px;
}
.ci-achievement-shelf::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.1);
  border-radius: 2px;
}
.ci-achievement-card {
  flex: 0 0 auto;
  width: 120px;
  border-radius: 12px;
  padding: 14px 10px;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(15, 15, 20, 0.5);
  position: relative;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
}
.ci-achievement-card:hover {
  transform: translateY(-2px);
}
.ci-achievement-card.locked {
  opacity: 0.45;
  filter: grayscale(0.6);
}
.ci-achievement-card .trophy-icon {
  width: 36px;
  height: 36px;
  margin: 0 auto 8px;
}
.ci-achievement-card .ach-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-primary, #fafafa);
  margin-bottom: 3px;
}
.ci-achievement-card .ach-desc {
  font-size: 9px;
  color: var(--color-text-secondary, #a1a1aa);
  line-height: 1.3;
}
.ci-achievement-card .ach-rarity {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  margin-top: 6px;
}
.ci-rarity-common    { color: #a1a1aa; }
.ci-rarity-rare      { color: #60a5fa; }
.ci-rarity-epic      { color: #fbbf24; }
.ci-rarity-legendary { color: #c084fc; }

.ci-rarity-glow-epic {
  box-shadow: 0 0 12px rgba(251, 191, 36, 0.20);
}
.ci-rarity-glow-legendary {
  box-shadow: 0 0 16px rgba(192, 132, 252, 0.25);
  border-color: rgba(192, 132, 252, 0.25);
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — MENTAL PERFORMANCE WHEEL
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-mental-wheel-container {
  display: flex;
  justify-content: center;
  padding: 12px 0;
}
.ci-mental-wheel-container svg {
  max-width: 280px;
}
.ci-mental-dim-card {
  display: flex;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 10px;
  margin-bottom: 8px;
  border-left: 3px solid transparent;
  transition: border-color 0.2s;
}
.ci-mental-dim-card:hover {
  border-left-color: var(--color-accent, #6366f1);
}
.ci-mental-dim-icon {
  font-size: 18px;
  width: 28px;
  text-align: center;
  flex-shrink: 0;
}
.ci-mental-dim-info {
  flex: 1;
}
.ci-mental-dim-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-primary, #fafafa);
  margin-bottom: 4px;
}
.ci-mental-dim-bar {
  height: 5px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
  margin-bottom: 4px;
}
.ci-mental-dim-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s ease;
}
.ci-mental-dim-insight {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
  font-style: italic;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — SEASON TIMELINE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-timeline-chart-container {
  overflow-x: auto;
  padding: 8px 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}
.ci-timeline-chart-container svg {
  display: block;
}
.ci-timeline-highlight {
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 8px;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-timeline-highlight-icon {
  font-size: 14px;
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — FORM & MOMENTUM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-sparkline-container {
  padding: 10px 0;
}
.ci-sparkline-container svg {
  max-width: 100%;
}
.ci-form-strip {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.ci-form-dot {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  border: 2px solid transparent;
  transition: transform 0.15s;
}
.ci-form-dot:hover {
  transform: scale(1.2);
}
.ci-form-dot.win   { background: rgba(34, 197, 94, 0.15); color: #22c55e; }
.ci-form-dot.draw  { background: rgba(245, 158, 11, 0.15); color: #f59e0b; }
.ci-form-dot.loss  { background: rgba(239, 68, 68, 0.15); color: #ef4444; }

.ci-streak-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 8px;
  margin-bottom: 8px;
}
.ci-streak-emoji {
  font-size: 20px;
}
.ci-streak-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-primary, #fafafa);
}
.ci-streak-detail {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — TRAJECTORY DEEP-DIVE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-trajectory-chart-container {
  padding: 10px 0;
  overflow-x: auto;
}
.ci-trajectory-chart-container svg {
  max-width: 100%;
  display: block;
}
.ci-model-weight-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.ci-model-weight-name {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
  width: 70px;
  flex-shrink: 0;
}
.ci-model-weight-track {
  flex: 1;
  height: 5px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}
.ci-model-weight-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s ease;
}
.ci-model-weight-pct {
  font-size: 10px;
  font-weight: 600;
  color: var(--color-text-primary, #fafafa);
  font-family: var(--font-mono, monospace);
  width: 32px;
  text-align: right;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — PHYSICAL DEVELOPMENT
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-fitness-test-card {
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.ci-fitness-test-value {
  font-size: 20px;
  font-weight: 800;
  font-family: var(--font-mono, monospace);
  color: var(--color-text-primary, #fafafa);
  min-width: 50px;
  text-align: center;
}
.ci-fitness-test-info {
  flex: 1;
}
.ci-fitness-test-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-primary, #fafafa);
  margin-bottom: 3px;
}
.ci-fitness-level-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.ci-acwr-zone {
  padding: 12px 16px;
  border-radius: 10px;
  text-align: center;
  margin-bottom: 12px;
}
.ci-acwr-zone.optimal {
  background: rgba(34, 197, 94, 0.08);
  border: 1px solid rgba(34, 197, 94, 0.15);
  color: var(--color-success, #22c55e);
}
.ci-acwr-zone.undertraining {
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.15);
  color: var(--color-warning, #f59e0b);
}
.ci-acwr-zone.overtraining {
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.15);
  color: var(--color-error, #ef4444);
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — POSITION INTELLIGENCE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-position-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.ci-position-bar-name {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
  width: 80px;
  flex-shrink: 0;
  text-align: right;
}
.ci-position-bar-track {
  flex: 1;
  height: 8px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}
.ci-position-bar-fill {
  height: 100%;
  border-radius: 4px;
  background: var(--color-accent, #6366f1);
  transition: width 0.6s ease;
}
.ci-position-card {
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 10px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.ci-heatmap-container {
  display: flex;
  justify-content: center;
  padding: 10px 0;
}
.ci-heatmap-container svg {
  max-width: 100%;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — AI RESPONSE SECTIONS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-ai-response {
  position: relative;
}
.ci-ai-narrative {
  position: relative;
}
.ci-ai-narrative::before {
  content: '❝';
  position: absolute;
  top: -6px;
  left: -4px;
  font-size: 28px;
  color: rgba(99, 102, 241, 0.2);
  font-family: Georgia, serif;
}
.ci-ai-loading {
  padding: 30px 20px;
}
@keyframes ciDotBounce {
  0%, 80%, 100% { transform: scale(0.4); opacity: 0.4; }
  40%           { transform: scale(1.0); opacity: 1; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — HISTOGRAM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-histogram-container {
  padding: 10px 0;
}
.ci-histogram-container svg {
  max-width: 100%;
  display: block;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — GAUGE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-gauge-container {
  display: flex;
  justify-content: center;
  padding: 10px 0;
}
.ci-gauge-container svg {
  max-width: 220px;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — COMPARISON BARS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-comparison-bars-container svg {
  max-width: 100%;
  display: block;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — LAZY RENDERING SKELETON
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-skeleton {
  animation: ciSkeletonPulse 1.8s ease-in-out infinite;
}
.ci-skeleton-bar {
  height: 14px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.05);
  margin-bottom: 10px;
}
.ci-skeleton-bar:nth-child(2) { width: 80%; }
.ci-skeleton-bar:nth-child(3) { width: 60%; }
.ci-skeleton-circle {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.05);
  margin: 0 auto 14px;
}
@keyframes ciSkeletonPulse {
  0%, 100% { opacity: 0.5; }
  50%      { opacity: 1; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — EMPTY STATES
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-empty-state {
  text-align: center;
  padding: 40px 20px;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-empty-state-icon {
  font-size: 36px;
  margin-bottom: 12px;
  opacity: 0.5;
}
.ci-empty-state-text {
  font-size: 12px;
  line-height: 1.6;
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — BENCHMARK TABLE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-benchmark-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}
.ci-benchmark-table th {
  text-align: left;
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--color-text-secondary, #a1a1aa);
  font-weight: 600;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.ci-benchmark-table td {
  padding: 7px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  color: var(--color-text-primary, #fafafa);
}
.ci-benchmark-table tr:hover td {
  background: rgba(255, 255, 255, 0.02);
}


/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — RESPONSIVE BREAKPOINTS
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
  .ci-premium-section {
    border-radius: 12px;
    margin-bottom: 18px;
  }
  .ci-premium-section-header {
    padding: 14px 16px 10px;
  }
  .ci-premium-section-body {
    padding: 0 16px 16px;
  }
  .ci-stat-row {
    gap: 8px;
  }
  .ci-pro-match-card {
    flex-direction: column;
    gap: 10px;
  }
}

@media (max-width: 640px) {
  .ci-tab-btn {
    padding: 6px 10px;
    font-size: 10px;
    min-width: 60px;
  }
  .ci-stat-card-value {
    font-size: 18px;
  }
  .ci-stat-card {
    padding: 10px 12px;
    min-width: 70px;
  }
  .ci-achievement-card {
    width: 100px;
    padding: 10px 8px;
  }
  .ci-mental-wheel-container svg {
    max-width: 220px;
  }
  .ci-fitness-test-card {
    flex-direction: column;
    text-align: center;
    gap: 8px;
  }
}

@media (max-width: 480px) {
  .ci-premium-section-title {
    font-size: 14px;
  }
  .ci-stat-row {
    flex-direction: column;
  }
  .ci-stat-row > * {
    min-width: auto;
  }
  .ci-position-bar-name {
    width: 60px;
    font-size: 10px;
  }
  .ci-benchmark-table {
    font-size: 10px;
  }
  .ci-benchmark-table th,
  .ci-benchmark-table td {
    padding: 5px 6px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED PRO COMPARISON SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-pro-comparison-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.ci-pro-match-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ci-pro-match-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
}
.ci-pro-match-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 40%, rgba(99, 102, 241, 0.03) 100%);
  opacity: 0;
  transition: opacity 0.25s;
}
.ci-pro-match-card:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(99, 102, 241, 0.2);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}
.ci-pro-match-card:hover::before { opacity: 1; }

.ci-pro-match-card.selected {
  border-color: var(--color-accent, #6366f1);
  background: rgba(99, 102, 241, 0.08);
  box-shadow: 0 0 0 1px var(--color-accent, #6366f1), 0 8px 32px rgba(99, 102, 241, 0.15);
}

.ci-pro-avatar {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.15), rgba(139, 92, 246, 0.15));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.ci-pro-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}
.ci-pro-avatar-badge {
  position: absolute;
  bottom: -2px;
  right: -2px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--color-surface, #18181b);
  border: 2px solid var(--color-accent, #6366f1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
}

.ci-pro-info {
  flex: 1;
  min-width: 0;
}
.ci-pro-player-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ci-pro-meta {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 2px;
}
.ci-pro-archetype-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 600;
  background: rgba(99, 102, 241, 0.12);
  color: var(--color-accent, #6366f1);
  margin-top: 4px;
}

.ci-pro-similarity-bar {
  width: 100%;
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  margin-top: 8px;
  overflow: hidden;
}
.ci-pro-similarity-fill {
  height: 100%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--color-accent, #6366f1), #8b5cf6);
  transition: width 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.ci-pro-similarity-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--color-accent, #6366f1);
  margin-top: 4px;
  text-align: right;
}

.ci-pro-detail-panel {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 20px;
  padding: 24px;
  position: sticky;
  top: 24px;
}

.ci-pro-detail-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  margin-bottom: 20px;
}
.ci-pro-detail-avatar {
  width: 72px;
  height: 72px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.2), rgba(139, 92, 246, 0.2));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
}
.ci-pro-detail-name {
  font-size: 20px;
  font-weight: 800;
  color: var(--color-text, #fafafa);
}
.ci-pro-detail-position {
  font-size: 13px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 2px;
}

.ci-pro-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 900px) {
  .ci-pro-detail-grid { grid-template-columns: 1fr; }
}

.ci-pro-stat-compare {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 16px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 12px;
}
.ci-pro-stat-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-pro-stat-values {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.ci-pro-stat-you {
  font-size: 18px;
  font-weight: 800;
  color: var(--color-accent, #6366f1);
}
.ci-pro-stat-vs {
  font-size: 10px;
  color: rgba(255, 255, 255, 0.3);
  font-weight: 600;
}
.ci-pro-stat-pro {
  font-size: 18px;
  font-weight: 800;
  color: var(--color-text, #fafafa);
}
.ci-pro-stat-delta {
  font-size: 11px;
  font-weight: 600;
  margin-top: 2px;
}
.ci-pro-stat-delta.positive { color: #22c55e; }
.ci-pro-stat-delta.negative { color: #ef4444; }
.ci-pro-stat-delta.neutral  { color: var(--color-text-secondary, #a1a1aa); }

.ci-pro-radar-wrapper {
  display: flex;
  justify-content: center;
  padding: 16px 0;
}
.ci-pro-radar-wrapper svg {
  max-width: 100%;
  height: auto;
}
.ci-pro-radar-legend {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-top: 12px;
  font-size: 12px;
}
.ci-pro-radar-legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.ci-pro-radar-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
.ci-pro-radar-legend-dot.you { background: var(--color-accent, #6366f1); }
.ci-pro-radar-legend-dot.pro { background: #ffd700; }

.ci-pro-tips-section {
  margin-top: 20px;
  padding: 16px;
  background: rgba(34, 197, 94, 0.05);
  border: 1px solid rgba(34, 197, 94, 0.1);
  border-radius: 14px;
}
.ci-pro-tips-title {
  font-size: 13px;
  font-weight: 700;
  color: #22c55e;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.ci-pro-tip-item {
  font-size: 12px;
  color: var(--color-text-secondary, #a1a1aa);
  padding: 6px 0;
  padding-left: 20px;
  position: relative;
}
.ci-pro-tip-item::before {
  content: '→';
  position: absolute;
  left: 0;
  color: #22c55e;
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED SEASON TIMELINE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-timeline-wrapper {
  position: relative;
  padding: 20px 0;
}

.ci-timeline-filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.ci-timeline-filter-btn {
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: var(--color-text-secondary, #a1a1aa);
  cursor: pointer;
  transition: all 0.2s;
}
.ci-timeline-filter-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}
.ci-timeline-filter-btn.active {
  background: rgba(99, 102, 241, 0.12);
  border-color: rgba(99, 102, 241, 0.3);
  color: var(--color-accent, #6366f1);
}

.ci-timeline-chart-wrapper {
  position: relative;
  overflow-x: auto;
  overflow-y: visible;
  padding-bottom: 16px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.1) transparent;
}
.ci-timeline-chart-wrapper::-webkit-scrollbar {
  height: 5px;
}
.ci-timeline-chart-wrapper::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 3px;
}

.ci-timeline-chart-container {
  min-width: 600px;
  padding: 8px 0;
}
.ci-timeline-chart-container svg {
  display: block;
  max-width: 100%;
}

.ci-timeline-tooltip {
  position: fixed;
  z-index: 1000;
  padding: 10px 14px;
  background: rgba(15, 15, 20, 0.95);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  font-size: 12px;
  color: var(--color-text, #fafafa);
  pointer-events: none;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
  max-width: 220px;
}
.ci-timeline-tooltip-title {
  font-weight: 700;
  margin-bottom: 4px;
}
.ci-timeline-tooltip-meta {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
}

.ci-timeline-season-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.ci-timeline-summary-card {
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 14px;
  text-align: center;
}
.ci-timeline-summary-value {
  font-size: 22px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--color-accent, #6366f1), #8b5cf6);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ci-timeline-summary-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 4px;
}

.ci-timeline-highlight {
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 10px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 12px;
  color: var(--color-text-secondary, #a1a1aa);
  border-left: 3px solid transparent;
  transition: all 0.2s;
}
.ci-timeline-highlight:hover {
  background: rgba(255, 255, 255, 0.04);
}
.ci-timeline-highlight[data-type="goal"]       { border-left-color: #22c55e; }
.ci-timeline-highlight[data-type="assist"]     { border-left-color: #3b82f6; }
.ci-timeline-highlight[data-type="hat_trick"]  { border-left-color: #ffd700; }
.ci-timeline-highlight[data-type="motm"]       { border-left-color: #ffd700; }
.ci-timeline-highlight[data-type="form_peak"]  { border-left-color: #22c55e; }
.ci-timeline-highlight[data-type="form_valley"]{ border-left-color: #ef4444; }
.ci-timeline-highlight[data-type="injury"]     { border-left-color: #ef4444; }
.ci-timeline-highlight[data-type="achievement"]{ border-left-color: #f59e0b; }

.ci-timeline-highlight-icon {
  font-size: 16px;
  flex-shrink: 0;
}
.ci-timeline-highlight-text {
  flex: 1;
}
.ci-timeline-highlight-date {
  font-size: 10px;
  color: rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED MENTAL PERFORMANCE SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-mental-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.ci-mental-wheel-panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.ci-mental-wheel-container {
  position: relative;
  width: 100%;
  max-width: 300px;
}
.ci-mental-wheel-container svg {
  max-width: 100%;
  height: auto;
}
.ci-mental-overall-score {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}
.ci-mental-overall-value {
  font-size: 36px;
  font-weight: 900;
  color: var(--color-text, #fafafa);
  line-height: 1;
}
.ci-mental-overall-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 4px;
}
.ci-mental-grade-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 16px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 800;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.ci-mental-dim-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ci-mental-dim-card {
  padding: 14px 18px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 14px;
  transition: all 0.2s;
}
.ci-mental-dim-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
}

.ci-mental-dim-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.ci-mental-dim-left {
  display: flex;
  align-items: center;
  gap: 10px;
}
.ci-mental-dim-icon {
  font-size: 18px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 10px;
}
.ci-mental-dim-info { flex: 1; }
.ci-mental-dim-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
}
.ci-mental-dim-desc {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 1px;
}
.ci-mental-dim-value {
  font-size: 20px;
  font-weight: 900;
  color: var(--color-text, #fafafa);
}

.ci-mental-dim-bar {
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 6px;
}
.ci-mental-dim-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.ci-mental-dim-insight {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
  font-style: italic;
  padding-left: 12px;
  border-left: 2px solid rgba(255, 255, 255, 0.06);
}

.ci-mental-pressure-chart {
  margin-top: 24px;
  padding: 20px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 16px;
}
.ci-mental-pressure-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED ACHIEVEMENT SHOWCASE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-achievement-showcase {
  position: relative;
}

.ci-achievement-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.ci-achievement-progress-text {
  font-size: 12px;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-achievement-progress-count {
  font-weight: 800;
  color: var(--color-accent, #6366f1);
}

.ci-achievement-progress-bar {
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 24px;
}
.ci-achievement-progress-fill {
  height: 100%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--color-accent, #6366f1), #8b5cf6, #ffd700);
  transition: width 1s cubic-bezier(0.22, 1, 0.36, 1);
}

.ci-achievement-rarity-section {
  margin-bottom: 28px;
}
.ci-achievement-rarity-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.ci-achievement-rarity-title.common    { color: #a1a1aa; }
.ci-achievement-rarity-title.rare      { color: #3b82f6; }
.ci-achievement-rarity-title.epic      { color: #a855f7; }
.ci-achievement-rarity-title.legendary { color: #ffd700; }

.ci-achievement-shelf {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding: 4px 0 12px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.06) transparent;
}
.ci-achievement-shelf::-webkit-scrollbar {
  height: 4px;
}
.ci-achievement-shelf::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 2px;
}

.ci-achievement-card {
  flex-shrink: 0;
  width: 130px;
  padding: 16px 12px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  text-align: center;
  cursor: default;
  transition: all 0.25s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
}
.ci-achievement-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.25s;
}
.ci-achievement-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.3);
}
.ci-achievement-card:hover::before { opacity: 1; }

/* Rarity border accents */
.ci-achievement-card[data-rarity="common"]::before {
  background: linear-gradient(180deg, rgba(161, 161, 170, 0.05), transparent 50%);
}
.ci-achievement-card[data-rarity="rare"]::before {
  background: linear-gradient(180deg, rgba(59, 130, 246, 0.08), transparent 50%);
}
.ci-achievement-card[data-rarity="rare"] {
  border-color: rgba(59, 130, 246, 0.12);
}
.ci-achievement-card[data-rarity="epic"]::before {
  background: linear-gradient(180deg, rgba(168, 85, 247, 0.08), transparent 50%);
}
.ci-achievement-card[data-rarity="epic"] {
  border-color: rgba(168, 85, 247, 0.12);
}
.ci-achievement-card[data-rarity="legendary"]::before {
  background: linear-gradient(180deg, rgba(255, 215, 0, 0.1), transparent 50%);
}
.ci-achievement-card[data-rarity="legendary"] {
  border-color: rgba(255, 215, 0, 0.15);
  background: linear-gradient(135deg, rgba(255, 215, 0, 0.02), rgba(255, 215, 0, 0.06));
}

.ci-achievement-card.locked {
  opacity: 0.4;
  filter: grayscale(0.6);
}
.ci-achievement-card.locked:hover {
  opacity: 0.6;
  filter: grayscale(0.3);
}

.ci-achievement-card .trophy-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
}
.ci-achievement-card .trophy-icon img {
  width: 100%;
  height: 100%;
}

.ci-achievement-card .ach-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
  margin-bottom: 4px;
  line-height: 1.3;
}
.ci-achievement-card .ach-desc {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
  line-height: 1.4;
}
.ci-achievement-card .ach-rarity {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 8px;
  border-radius: 10px;
  margin-top: 8px;
}
.ci-achievement-card .ach-rarity.common    { background: rgba(161, 161, 170, 0.12); color: #a1a1aa; }
.ci-achievement-card .ach-rarity.rare      { background: rgba(59, 130, 246, 0.12);  color: #3b82f6; }
.ci-achievement-card .ach-rarity.epic      { background: rgba(168, 85, 247, 0.12);  color: #a855f7; }
.ci-achievement-card .ach-rarity.legendary { background: rgba(255, 215, 0, 0.12);   color: #ffd700; }

.ci-achievement-shelf-container {
  margin-top: 16px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED AI PANEL
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-ai-panel {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ci-ai-feature-card {
  padding: 20px 24px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
}
.ci-ai-feature-card::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 80px;
  height: 80px;
  background: radial-gradient(circle at top right, rgba(99, 102, 241, 0.06), transparent 70%);
  pointer-events: none;
}
.ci-ai-feature-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(99, 102, 241, 0.2);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.ci-ai-feature-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.ci-ai-feature-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  background: rgba(99, 102, 241, 0.1);
}
.ci-ai-feature-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
}
.ci-ai-feature-desc {
  font-size: 12px;
  color: var(--color-text-secondary, #a1a1aa);
  line-height: 1.6;
}
.ci-ai-feature-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.15), rgba(139, 92, 246, 0.15));
  color: var(--color-accent, #6366f1);
  margin-left: auto;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ci-ai-response {
  padding: 20px 24px;
  background: rgba(99, 102, 241, 0.03);
  border: 1px solid rgba(99, 102, 241, 0.1);
  border-radius: 16px;
  font-size: 13px;
  line-height: 1.8;
  color: var(--color-text, #fafafa);
  position: relative;
}
.ci-ai-response::before {
  content: '✨';
  position: absolute;
  top: -10px;
  left: 20px;
  font-size: 20px;
  background: var(--color-surface, #18181b);
  padding: 0 6px;
}

.ci-ai-narrative {
  white-space: pre-line;
  line-height: 1.8;
}

.ci-ai-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  gap: 16px;
}
.ci-ai-loading-text {
  font-size: 13px;
  color: var(--color-text-secondary, #a1a1aa);
}

.ci-ai-typing {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 10px 18px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 20px;
}
.ci-ai-typing-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-accent, #6366f1);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — LAZY SECTION CONTAINERS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-v7-lazy-container {
  min-height: 200px;
  position: relative;
}

.ci-v7-loading-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  opacity: 0.5;
  text-align: center;
}
.ci-v7-loading-placeholder .placeholder-icon {
  font-size: 32px;
  margin-bottom: 12px;
}
.ci-v7-loading-placeholder .placeholder-text {
  font-size: 13px;
  color: var(--color-text-secondary, #a1a1aa);
}

.ci-section {
  margin-bottom: 24px;
}
.ci-section__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 14px 14px 0 0;
  cursor: pointer;
  transition: background 0.2s;
  user-select: none;
}
.ci-section__header:hover {
  background: rgba(255, 255, 255, 0.04);
}
.ci-section__icon {
  font-size: 18px;
  flex-shrink: 0;
}
.ci-section__title {
  flex: 1;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
}
.ci-section__chevron {
  font-size: 12px;
  color: var(--color-text-secondary, #a1a1aa);
  transition: transform 0.2s;
}
.ci-section.collapsed .ci-section__chevron {
  transform: rotate(-90deg);
}
.ci-section__body {
  padding: 18px;
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-top: none;
  border-radius: 0 0 14px 14px;
}
.ci-section.collapsed .ci-section__body {
  display: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — TAB PANEL FADE ANIMATION
   ═══════════════════════════════════════════════════════════════════════════ */

@keyframes ciTabFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.ci-tab-panel.active {
  animation: ciTabFadeIn 0.3s cubic-bezier(0.22, 1, 0.36, 1) both;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — FORM GRADE BADGES
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-form-grade {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 900;
  border: 2px solid;
}
.ci-form-grade.S { background: rgba(255, 215, 0, 0.12); border-color: #ffd700; color: #ffd700; }
.ci-form-grade.A { background: rgba(34, 197, 94, 0.12); border-color: #22c55e; color: #22c55e; }
.ci-form-grade.B { background: rgba(99, 102, 241, 0.12); border-color: #6366f1; color: #6366f1; }
.ci-form-grade.C { background: rgba(245, 158, 11, 0.12); border-color: #f59e0b; color: #f59e0b; }
.ci-form-grade.D { background: rgba(249, 115, 22, 0.12); border-color: #f97316; color: #f97316; }
.ci-form-grade.F { background: rgba(239, 68, 68, 0.12); border-color: #ef4444; color: #ef4444; }

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED TRAJECTORY DEEP-DIVE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-trajectory-panel {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.ci-model-ensemble {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
.ci-model-card {
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}
.ci-model-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 100%;
  border-radius: 3px 0 0 3px;
}
.ci-model-card[data-model="linear"]::before    { background: #6366f1; }
.ci-model-card[data-model="quadratic"]::before { background: #22c55e; }
.ci-model-card[data-model="loess"]::before     { background: #f59e0b; }
.ci-model-card[data-model="logistic"]::before  { background: #ef4444; }

.ci-model-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
  margin-bottom: 4px;
}
.ci-model-prediction {
  font-size: 20px;
  font-weight: 900;
}
.ci-model-rmse {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 4px;
}
.ci-model-weight-bar {
  height: 4px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 2px;
  margin-top: 8px;
  overflow: hidden;
}
.ci-model-weight-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.ci-confidence-band {
  padding: 16px 20px;
  background: rgba(99, 102, 241, 0.04);
  border: 1px solid rgba(99, 102, 241, 0.1);
  border-radius: 14px;
  text-align: center;
}
.ci-confidence-range {
  font-size: 24px;
  font-weight: 900;
  color: var(--color-text, #fafafa);
}
.ci-confidence-label {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 4px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — PHYSICAL FITNESS SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-fitness-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px;
}

.ci-fitness-test-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 14px;
  transition: all 0.2s;
}
.ci-fitness-test-card:hover {
  background: rgba(255, 255, 255, 0.04);
}
.ci-fitness-test-card[data-level="elite"]    { border-color: rgba(255, 215, 0, 0.15); }
.ci-fitness-test-card[data-level="advanced"] { border-color: rgba(34, 197, 94, 0.12); }
.ci-fitness-test-card[data-level="good"]     { border-color: rgba(99, 102, 241, 0.12); }

.ci-fitness-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  background: rgba(255, 255, 255, 0.04);
  flex-shrink: 0;
}
.ci-fitness-info { flex: 1; }
.ci-fitness-test-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
}
.ci-fitness-test-value {
  font-size: 18px;
  font-weight: 900;
}
.ci-fitness-test-level {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.ci-fitness-target {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-fitness-target-met   { color: #22c55e; }
.ci-fitness-target-unmet { color: #f97316; }

.ci-acwr-card {
  padding: 20px 24px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  text-align: center;
}
.ci-acwr-value {
  font-size: 32px;
  font-weight: 900;
}
.ci-acwr-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 4px;
}
.ci-acwr-zone {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  margin-top: 8px;
}
.ci-acwr-zone.optimal       { background: rgba(34, 197, 94, 0.12); color: #22c55e; }
.ci-acwr-zone.undertraining { background: rgba(59, 130, 246, 0.12); color: #3b82f6; }
.ci-acwr-zone.overtraining  { background: rgba(239, 68, 68, 0.12); color: #ef4444; }

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — POSITION INTELLIGENCE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-position-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}
.ci-position-card {
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 14px;
}
.ci-position-card.primary {
  border-color: rgba(99, 102, 241, 0.2);
  background: rgba(99, 102, 241, 0.05);
}
.ci-position-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
}
.ci-position-matches {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 2px;
}
.ci-position-bar {
  height: 5px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 8px;
}
.ci-position-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.ci-position-stats {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED STAT DISTRIBUTION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-stat-dist-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
}
.ci-stat-dist-card {
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 12px;
  text-align: center;
}
.ci-stat-dist-value {
  font-size: 22px;
  font-weight: 900;
  color: var(--color-text, #fafafa);
}
.ci-stat-dist-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 3px;
}
.ci-stat-dist-total {
  font-size: 10px;
  color: rgba(255, 255, 255, 0.3);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — BENCHMARK TABLE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-benchmark-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.ci-benchmark-table th {
  padding: 8px 12px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-secondary, #a1a1aa);
  text-align: left;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.ci-benchmark-table td {
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  color: var(--color-text, #fafafa);
}
.ci-benchmark-table tr:hover td {
  background: rgba(255, 255, 255, 0.02);
}
.ci-benchmark-value {
  font-weight: 800;
}
.ci-benchmark-delta.positive { color: #22c55e; }
.ci-benchmark-delta.negative { color: #ef4444; }

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — EMPTY STATE
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 24px;
  text-align: center;
}
.ci-empty-state-icon {
  font-size: 48px;
  margin-bottom: 16px;
  opacity: 0.5;
}
.ci-empty-state-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
  margin-bottom: 8px;
}
.ci-empty-state-message {
  font-size: 13px;
  color: var(--color-text-secondary, #a1a1aa);
  max-width: 380px;
  line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED AMBIENT EFFECTS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-premium-ambient::before,
.ci-premium-ambient::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 0;
}
.ci-premium-ambient::before {
  width: 400px;
  height: 400px;
  top: -100px;
  right: -100px;
  background: radial-gradient(circle, rgba(99, 102, 241, 0.06) 0%, transparent 70%);
}
.ci-premium-ambient::after {
  width: 300px;
  height: 300px;
  bottom: -80px;
  left: -60px;
  background: radial-gradient(circle, rgba(139, 92, 246, 0.04) 0%, transparent 70%);
}

.ci-v7-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
  mix-blend-mode: screen;
}
.ci-v7-orb-1 {
  width: 250px;
  height: 250px;
  background: rgba(99, 102, 241, 0.05);
  top: 20%;
  left: -5%;
}
.ci-v7-orb-2 {
  width: 200px;
  height: 200px;
  background: rgba(139, 92, 246, 0.04);
  bottom: 10%;
  right: -5%;
}
.ci-v7-orb-3 {
  width: 180px;
  height: 180px;
  background: rgba(255, 215, 0, 0.02);
  top: 50%;
  left: 40%;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — ENHANCED 8-TAB NAVIGATION
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-tabs-container {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  margin-bottom: 24px;
}
.ci-tabs-container::-webkit-scrollbar {
  display: none;
}

.ci-tab-nav {
  display: flex;
  gap: 4px;
  min-width: max-content;
  padding: 4px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 14px;
}

.ci-tab-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-secondary, #a1a1aa);
  background: transparent;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
}
.ci-tab-btn:hover {
  background: rgba(255, 255, 255, 0.04);
  color: var(--color-text, #fafafa);
}
.ci-tab-btn.active {
  background: rgba(99, 102, 241, 0.12);
  color: var(--color-accent, #6366f1);
  font-weight: 700;
}
.ci-tab-btn .tab-icon {
  font-size: 14px;
}
.ci-tab-btn .tab-label {
  font-size: inherit;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — RESPONSIVE REFINEMENTS
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 1200px) {
  .ci-pro-comparison-wrapper {
    grid-template-columns: 1fr;
  }
  .ci-pro-detail-panel {
    position: static;
  }
  .ci-mental-wrapper {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .ci-pro-comparison-wrapper {
    grid-template-columns: 1fr;
  }
  .ci-pro-detail-grid {
    grid-template-columns: 1fr;
  }
  .ci-mental-wrapper {
    grid-template-columns: 1fr;
  }
  .ci-model-ensemble {
    grid-template-columns: repeat(2, 1fr);
  }
  .ci-timeline-season-summary {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .ci-tab-btn {
    padding: 8px 12px;
    font-size: 11px;
  }
  .ci-tab-btn .tab-label {
    display: none;
  }
  .ci-tab-btn .tab-icon {
    font-size: 16px;
  }
  .ci-pro-match-card {
    padding: 12px 14px;
    gap: 12px;
  }
  .ci-pro-avatar {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    font-size: 22px;
  }
  .ci-achievement-card {
    width: 110px;
    padding: 12px 10px;
  }
  .ci-achievement-card .trophy-icon {
    width: 36px;
    height: 36px;
    font-size: 22px;
  }
  .ci-mental-wheel-container {
    max-width: 240px;
  }
  .ci-fitness-grid {
    grid-template-columns: 1fr;
  }
  .ci-model-ensemble {
    grid-template-columns: 1fr;
  }
  .ci-stat-card-value {
    font-size: 20px;
  }
  .ci-stat-dist-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .ci-timeline-season-summary {
    grid-template-columns: 1fr;
  }
  .ci-pro-radar-legend {
    font-size: 10px;
    gap: 12px;
  }
}

@media (max-width: 480px) {
  .ci-section__header {
    padding: 10px 14px;
  }
  .ci-section__body {
    padding: 12px;
  }
  .ci-pro-detail-panel {
    padding: 16px;
  }
  .ci-ai-feature-card {
    padding: 14px 16px;
  }
  .ci-timeline-tooltip {
    max-width: 180px;
  }
  .ci-achievement-card {
    width: 100px;
    padding: 10px 8px;
  }
  .ci-mental-dim-card {
    padding: 10px 14px;
  }
  .ci-mental-dim-value {
    font-size: 16px;
  }
  .ci-mental-overall-value {
    font-size: 28px;
  }
  .ci-benchmark-table {
    font-size: 10px;
  }
  .ci-benchmark-table th,
  .ci-benchmark-table td {
    padding: 6px 8px;
  }
  .ci-position-grid {
    grid-template-columns: 1fr;
  }
  .ci-stat-dist-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — SVG CHART STYLING
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-chart-container {
  position: relative;
  padding: 8px;
}
.ci-chart-container svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Dual Radar Chart */
.ci-dual-radar-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.ci-dual-radar-container svg text {
  font-family: inherit;
  fill: var(--color-text-secondary, #a1a1aa);
  font-size: 10px;
}
.ci-dual-radar-container svg text.radar-label {
  font-weight: 600;
  fill: var(--color-text, #fafafa);
}
.ci-dual-radar-container svg circle.radar-grid {
  fill: none;
  stroke: rgba(255, 255, 255, 0.05);
  stroke-width: 1;
}
.ci-dual-radar-container svg line.radar-axis {
  stroke: rgba(255, 255, 255, 0.06);
  stroke-width: 1;
}
.ci-dual-radar-container svg polygon.radar-area-you {
  fill: rgba(99, 102, 241, 0.15);
  stroke: var(--color-accent, #6366f1);
  stroke-width: 2;
  stroke-linejoin: round;
}
.ci-dual-radar-container svg polygon.radar-area-pro {
  fill: rgba(255, 215, 0, 0.1);
  stroke: #ffd700;
  stroke-width: 2;
  stroke-linejoin: round;
  stroke-dasharray: 5 3;
}
.ci-dual-radar-container svg circle.radar-dot-you {
  fill: var(--color-accent, #6366f1);
  stroke: var(--color-surface, #18181b);
  stroke-width: 2;
  r: 4;
  transition: r 0.15s ease;
}
.ci-dual-radar-container svg circle.radar-dot-you:hover {
  r: 6;
}
.ci-dual-radar-container svg circle.radar-dot-pro {
  fill: #ffd700;
  stroke: var(--color-surface, #18181b);
  stroke-width: 2;
  r: 3.5;
}

/* Pressure Gauge */
.ci-gauge-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.ci-gauge-container svg text.gauge-value {
  fill: var(--color-text, #fafafa);
  font-size: 26px;
  font-weight: 900;
  text-anchor: middle;
  dominant-baseline: middle;
}
.ci-gauge-container svg text.gauge-label {
  fill: var(--color-text-secondary, #a1a1aa);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  text-anchor: middle;
}
.ci-gauge-container svg path.gauge-track {
  fill: none;
  stroke: rgba(255, 255, 255, 0.06);
  stroke-width: 14;
  stroke-linecap: round;
}
.ci-gauge-container svg path.gauge-fill {
  fill: none;
  stroke-width: 14;
  stroke-linecap: round;
  transition: stroke-dashoffset 1s cubic-bezier(0.22, 1, 0.36, 1);
}
.ci-gauge-container svg circle.gauge-needle-dot {
  fill: var(--color-text, #fafafa);
  r: 5;
  filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.3));
}

/* Sparkline Chart */
.ci-sparkline-container {
  overflow: hidden;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.01);
}
.ci-sparkline-container svg path.sparkline {
  fill: none;
  stroke: var(--color-accent, #6366f1);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.ci-sparkline-container svg path.sparkline-area {
  fill: url(#sparklineGradient);
  opacity: 0.3;
}
.ci-sparkline-container svg circle.sparkline-dot {
  fill: var(--color-accent, #6366f1);
  stroke: var(--color-surface, #18181b);
  stroke-width: 2;
  r: 0;
  transition: r 0.15s ease;
}
.ci-sparkline-container:hover svg circle.sparkline-dot {
  r: 4;
}

/* Comparison Bars */
.ci-comparison-bar-container {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ci-comparison-bar-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ci-comparison-bar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ci-comparison-bar-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text, #fafafa);
}
.ci-comparison-bar-values {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
}
.ci-comparison-bar-you-val {
  font-weight: 700;
  color: var(--color-accent, #6366f1);
}
.ci-comparison-bar-pro-val {
  font-weight: 700;
  color: #ffd700;
}
.ci-comparison-bar-track {
  height: 8px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}
.ci-comparison-bar-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--color-accent, #6366f1), #8b5cf6);
  transition: width 0.7s cubic-bezier(0.22, 1, 0.36, 1);
  z-index: 2;
}
.ci-comparison-bar-ghost {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  border-radius: 4px;
  background: rgba(255, 215, 0, 0.15);
  border-right: 2px solid #ffd700;
  transition: width 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.1s;
  z-index: 1;
}

/* Heatmap */
.ci-heatmap-container {
  position: relative;
  padding: 8px;
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 14px;
}
.ci-heatmap-container svg rect.heat-cell {
  rx: 2;
  ry: 2;
  transition: opacity 0.15s;
}
.ci-heatmap-container svg rect.heat-cell:hover {
  stroke: var(--color-text, #fafafa);
  stroke-width: 1;
}
.ci-heatmap-legend {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-heatmap-legend-bar {
  width: 80px;
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(90deg, rgba(99, 102, 241, 0.1), rgba(99, 102, 241, 0.4), #6366f1, #8b5cf6);
}

/* Histogram */
.ci-histogram-container {
  padding: 8px;
}
.ci-histogram-container svg rect.hist-bar {
  fill: var(--color-accent, #6366f1);
  rx: 2;
  ry: 0;
  opacity: 0.7;
  transition: opacity 0.15s, fill 0.15s;
}
.ci-histogram-container svg rect.hist-bar:hover {
  opacity: 1;
  fill: #8b5cf6;
}
.ci-histogram-container svg rect.hist-bar-highlight {
  fill: #ffd700;
  opacity: 0.9;
}
.ci-histogram-container svg line.hist-axis {
  stroke: rgba(255, 255, 255, 0.08);
  stroke-width: 1;
}
.ci-histogram-container svg text.hist-label {
  fill: var(--color-text-secondary, #a1a1aa);
  font-size: 9px;
}

/* Momentum Chart */
.ci-momentum-chart-container {
  position: relative;
  padding: 8px;
}
.ci-momentum-chart-container svg path.momentum-line {
  fill: none;
  stroke: var(--color-accent, #6366f1);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.ci-momentum-chart-container svg path.momentum-area {
  fill: url(#momentumGradient);
  opacity: 0.15;
}
.ci-momentum-chart-container svg line.momentum-threshold {
  stroke-dasharray: 4 4;
  stroke-width: 1;
}
.ci-momentum-chart-container svg line.threshold-hot {
  stroke: rgba(34, 197, 94, 0.3);
}
.ci-momentum-chart-container svg line.threshold-cold {
  stroke: rgba(239, 68, 68, 0.3);
}
.ci-momentum-chart-container svg circle.momentum-point {
  fill: var(--color-accent, #6366f1);
  stroke: var(--color-surface, #18181b);
  stroke-width: 2;
  r: 3;
  transition: r 0.15s ease;
}
.ci-momentum-chart-container svg circle.momentum-point:hover {
  r: 5;
}
.ci-momentum-chart-container svg circle.momentum-point.hot {
  fill: #22c55e;
}
.ci-momentum-chart-container svg circle.momentum-point.cold {
  fill: #ef4444;
}

/* Trajectory Chart */
.ci-trajectory-chart-container {
  position: relative;
  padding: 12px 8px;
}
.ci-trajectory-chart-container svg path.trajectory-actual {
  fill: none;
  stroke: var(--color-text, #fafafa);
  stroke-width: 2;
  stroke-linecap: round;
}
.ci-trajectory-chart-container svg path.trajectory-predicted {
  fill: none;
  stroke-width: 2;
  stroke-dasharray: 6 3;
  stroke-linecap: round;
}
.ci-trajectory-chart-container svg path.trajectory-linear    { stroke: #6366f1; }
.ci-trajectory-chart-container svg path.trajectory-quadratic { stroke: #22c55e; }
.ci-trajectory-chart-container svg path.trajectory-loess     { stroke: #f59e0b; }
.ci-trajectory-chart-container svg path.trajectory-logistic  { stroke: #ef4444; }

.ci-trajectory-chart-container svg path.confidence-area {
  fill: rgba(99, 102, 241, 0.06);
  stroke: none;
}
.ci-trajectory-chart-container svg circle.trajectory-data-point {
  fill: var(--color-text, #fafafa);
  stroke: var(--color-surface, #18181b);
  stroke-width: 2;
  r: 3;
}

/* Form Strip */
.ci-form-strip-container {
  display: flex;
  align-items: center;
  gap: 3px;
  padding: 8px 0;
}
.ci-form-strip-dot {
  width: 14px;
  height: 14px;
  border-radius: 3px;
  transition: transform 0.15s ease;
}
.ci-form-strip-dot:hover {
  transform: scaleY(1.5);
}
.ci-form-strip-dot.win  { background: #22c55e; }
.ci-form-strip-dot.draw { background: #f59e0b; }
.ci-form-strip-dot.loss { background: #ef4444; }

/* Timeline SVG */
.ci-season-timeline-svg {
  position: relative;
}
.ci-season-timeline-svg svg path.timeline-line {
  fill: none;
  stroke: var(--color-accent, #6366f1);
  stroke-width: 2;
  stroke-linecap: round;
}
.ci-season-timeline-svg svg path.timeline-area {
  fill: url(#timelineGradient);
  opacity: 0.1;
}
.ci-season-timeline-svg svg circle.timeline-node {
  fill: var(--color-surface, #18181b);
  stroke: var(--color-accent, #6366f1);
  stroke-width: 2;
  r: 5;
  cursor: pointer;
  transition: r 0.15s ease;
}
.ci-season-timeline-svg svg circle.timeline-node:hover {
  r: 7;
  fill: var(--color-accent, #6366f1);
}
.ci-season-timeline-svg svg circle.timeline-node.milestone {
  r: 7;
  fill: #ffd700;
  stroke: #ffd700;
}
.ci-season-timeline-svg svg circle.timeline-node.negative {
  stroke: #ef4444;
}
.ci-season-timeline-svg svg text.timeline-date {
  fill: var(--color-text-secondary, #a1a1aa);
  font-size: 9px;
}
.ci-season-timeline-svg svg text.timeline-event-label {
  fill: var(--color-text, #fafafa);
  font-size: 10px;
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — PREMIUM CARD SYSTEM (EXTENDED)
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-premium-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 20px;
  padding: 24px;
  position: relative;
  overflow: hidden;
}

.ci-premium-card--accent {
  border-color: rgba(99, 102, 241, 0.15);
}
.ci-premium-card--accent::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-accent, #6366f1), transparent);
}

.ci-premium-card--gold {
  border-color: rgba(255, 215, 0, 0.12);
}
.ci-premium-card--gold::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, #ffd700, transparent);
}

.ci-premium-card--glass {
  background: rgba(15, 15, 20, 0.6);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.ci-premium-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}
.ci-premium-card__title {
  font-size: 15px;
  font-weight: 800;
  color: var(--color-text, #fafafa);
  display: flex;
  align-items: center;
  gap: 8px;
}
.ci-premium-card__title-icon {
  font-size: 16px;
}
.ci-premium-card__badge {
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ci-premium-card__badge--pro {
  background: rgba(99, 102, 241, 0.12);
  color: var(--color-accent, #6366f1);
}
.ci-premium-card__badge--new {
  background: rgba(34, 197, 94, 0.12);
  color: #22c55e;
}
.ci-premium-card__badge--beta {
  background: rgba(245, 158, 11, 0.12);
  color: #f59e0b;
}

.ci-premium-card__divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.05);
  margin: 16px 0;
}

.ci-premium-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  margin-top: 16px;
}
.ci-premium-card__footer-text {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — MICRO INTERACTIONS & HOVER STATES
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-hover-lift {
  transition: transform 0.25s cubic-bezier(0.22, 1, 0.36, 1), 
              box-shadow 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}
.ci-hover-lift:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
}

.ci-hover-glow {
  transition: box-shadow 0.3s;
}
.ci-hover-glow:hover {
  box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.15),
              0 0 20px rgba(99, 102, 241, 0.08);
}

.ci-hover-border {
  transition: border-color 0.2s;
}
.ci-hover-border:hover {
  border-color: rgba(255, 255, 255, 0.12);
}

.ci-press-scale {
  transition: transform 0.1s;
}
.ci-press-scale:active {
  transform: scale(0.97);
}

/* Focus visible for keyboard nav */
.ci-focusable:focus-visible {
  outline: 2px solid var(--color-accent, #6366f1);
  outline-offset: 2px;
  border-radius: 8px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — SKELETON LOADERS (SECTION SPECIFIC)
   ═══════════════════════════════════════════════════════════════════════════ */

@keyframes ciShimmer {
  0%   { background-position: -200px 0; }
  100% { background-position: 200px 0; }
}

.ci-skeleton {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.04) 0%,
    rgba(255, 255, 255, 0.08) 50%,
    rgba(255, 255, 255, 0.04) 100%
  );
  background-size: 400px 100%;
  animation: ciShimmer 1.5s infinite linear;
  border-radius: 8px;
}

.ci-skeleton-text {
  height: 12px;
  margin-bottom: 8px;
  width: 80%;
}
.ci-skeleton-text.short { width: 40%; }
.ci-skeleton-text.medium { width: 60%; }

.ci-skeleton-card {
  height: 120px;
  border-radius: 16px;
}

.ci-skeleton-avatar {
  width: 48px;
  height: 48px;
  border-radius: 12px;
}

.ci-skeleton-bar {
  height: 6px;
  border-radius: 3px;
}

.ci-skeleton-chart {
  height: 200px;
  border-radius: 14px;
}

.ci-skeleton-circle {
  border-radius: 50%;
}

/* Achievement skeleton layout */
.ci-skeleton-shelf {
  display: flex;
  gap: 12px;
  overflow: hidden;
}
.ci-skeleton-shelf-item {
  width: 130px;
  height: 160px;
  border-radius: 16px;
  flex-shrink: 0;
}

/* Pro comparison skeleton */
.ci-skeleton-comparison {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.ci-skeleton-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ci-skeleton-list-item {
  height: 80px;
  border-radius: 16px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — GRADIENT TEXT UTILITIES
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-gradient-text {
  background: linear-gradient(135deg, var(--color-accent, #6366f1), #8b5cf6);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.ci-gradient-text--gold {
  background: linear-gradient(135deg, #ffd700, #f59e0b);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.ci-gradient-text--success {
  background: linear-gradient(135deg, #22c55e, #10b981);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.ci-gradient-text--cyan {
  background: linear-gradient(135deg, #00f0ff, #06b6d4);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — TOOLTIP SYSTEM
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-tooltip {
  position: fixed;
  z-index: 10000;
  padding: 8px 12px;
  background: rgba(15, 15, 20, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  font-size: 11px;
  color: var(--color-text, #fafafa);
  pointer-events: none;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.15s, transform 0.15s;
  max-width: 200px;
}
.ci-tooltip.visible {
  opacity: 1;
  transform: translateY(0);
}
.ci-tooltip-arrow {
  position: absolute;
  bottom: -4px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 8px;
  height: 8px;
  background: rgba(15, 15, 20, 0.95);
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — NOTIFICATION TOASTS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 10001;
  padding: 12px 20px;
  background: rgba(15, 15, 20, 0.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  font-size: 13px;
  color: var(--color-text, #fafafa);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
  display: flex;
  align-items: center;
  gap: 10px;
  transform: translateY(20px);
  opacity: 0;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
              opacity 0.3s;
}
.ci-toast.active {
  transform: translateY(0);
  opacity: 1;
}
.ci-toast-icon {
  font-size: 18px;
  flex-shrink: 0;
}
.ci-toast-message {
  flex: 1;
}
.ci-toast.success { border-left: 3px solid #22c55e; }
.ci-toast.error   { border-left: 3px solid #ef4444; }
.ci-toast.info    { border-left: 3px solid var(--color-accent, #6366f1); }

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — COLLAPSIBLE INFO ROWS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-info-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  font-size: 12px;
}
.ci-info-row:last-child { border-bottom: none; }
.ci-info-row-label {
  color: var(--color-text-secondary, #a1a1aa);
  font-weight: 500;
}
.ci-info-row-value {
  color: var(--color-text, #fafafa);
  font-weight: 700;
}

.ci-info-group {
  margin-bottom: 16px;
}
.ci-info-group-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-secondary, #a1a1aa);
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — PROGRESS INDICATORS
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-progress-ring {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ci-progress-ring svg circle.progress-bg {
  fill: none;
  stroke: rgba(255, 255, 255, 0.06);
}
.ci-progress-ring svg circle.progress-fill {
  fill: none;
  stroke-linecap: round;
  transform: rotate(-90deg);
  transform-origin: center;
  transition: stroke-dashoffset 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.ci-progress-ring-label {
  position: absolute;
  font-size: 12px;
  font-weight: 800;
  color: var(--color-text, #fafafa);
}

.ci-progress-steps {
  display: flex;
  align-items: center;
  gap: 0;
}
.ci-progress-step {
  display: flex;
  align-items: center;
  gap: 0;
}
.ci-progress-step-dot {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  border: 2px solid rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  color: var(--color-text-secondary, #a1a1aa);
  flex-shrink: 0;
}
.ci-progress-step.completed .ci-progress-step-dot {
  background: var(--color-accent, #6366f1);
  border-color: var(--color-accent, #6366f1);
  color: white;
}
.ci-progress-step.active .ci-progress-step-dot {
  border-color: var(--color-accent, #6366f1);
  color: var(--color-accent, #6366f1);
}
.ci-progress-step-line {
  width: 32px;
  height: 2px;
  background: rgba(255, 255, 255, 0.06);
}
.ci-progress-step.completed + .ci-progress-step .ci-progress-step-line,
.ci-progress-step.completed .ci-progress-step-line {
  background: var(--color-accent, #6366f1);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — MATCH CARDS (v7 Enhanced)
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-match-card-v7 {
  display: flex;
  gap: 16px;
  padding: 16px 20px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  transition: all 0.2s;
}
.ci-match-card-v7:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
}
.ci-match-card-v7__score {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 48px;
}
.ci-match-card-v7__result {
  font-size: 18px;
  font-weight: 900;
}
.ci-match-card-v7__result.win  { color: #22c55e; }
.ci-match-card-v7__result.draw { color: #f59e0b; }
.ci-match-card-v7__result.loss { color: #ef4444; }
.ci-match-card-v7__scoreline {
  font-size: 10px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 2px;
}
.ci-match-card-v7__body {
  flex: 1;
  min-width: 0;
}
.ci-match-card-v7__opponent {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text, #fafafa);
}
.ci-match-card-v7__meta {
  font-size: 11px;
  color: var(--color-text-secondary, #a1a1aa);
  margin-top: 2px;
}
.ci-match-card-v7__stats {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  font-size: 10px;
}
.ci-match-card-v7__stat {
  display: flex;
  align-items: center;
  gap: 4px;
  color: var(--color-text-secondary, #a1a1aa);
}
.ci-match-card-v7__stat-value {
  font-weight: 700;
  color: var(--color-text, #fafafa);
}
.ci-match-card-v7__rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 40px;
}
.ci-match-card-v7__rating-value {
  font-size: 20px;
  font-weight: 900;
}
.ci-match-card-v7__rating-label {
  font-size: 9px;
  color: var(--color-text-secondary, #a1a1aa);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — SCROLLBAR THEME
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-custom-scroll {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.08) transparent;
}
.ci-custom-scroll::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}
.ci-custom-scroll::-webkit-scrollbar-track {
  background: transparent;
}
.ci-custom-scroll::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
}
.ci-custom-scroll::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.14);
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — RESPONSIVE: EXTRA BREAKPOINTS FOR V7 CHARTS
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 1440px) {
  .ci-pro-comparison-wrapper {
    gap: 20px;
  }
  .ci-model-ensemble {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 1024px) {
  .ci-dual-radar-container svg {
    max-width: 280px;
  }
  .ci-gauge-container svg {
    max-width: 220px;
  }
  .ci-timeline-chart-container {
    min-width: 500px;
  }
}

@media (max-width: 768px) {
  .ci-comparison-bar-track {
    height: 6px;
  }
  .ci-heatmap-container {
    overflow-x: auto;
  }
  .ci-skeleton-comparison {
    grid-template-columns: 1fr;
  }
  .ci-match-card-v7 {
    flex-direction: column;
    gap: 10px;
  }
  .ci-match-card-v7__score {
    flex-direction: row;
    gap: 8px;
  }
  .ci-match-card-v7__rating {
    flex-direction: row;
    gap: 6px;
  }
  .ci-toast {
    left: 16px;
    right: 16px;
    bottom: 16px;
  }
}

@media (max-width: 480px) {
  .ci-pro-radar-legend {
    flex-direction: column;
    gap: 4px;
  }
  .ci-trajectory-chart-container {
    padding: 4px 0;
  }
  .ci-momentum-chart-container {
    padding: 4px 0;
  }
  .ci-form-strip-dot {
    width: 10px;
    height: 10px;
  }
  .ci-histogram-container svg text.hist-label {
    font-size: 7px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — PRINT STYLES
   ═══════════════════════════════════════════════════════════════════════════ */

@media print {
  .ci-v7-orb,
  .ci-premium-ambient::before,
  .ci-premium-ambient::after,
  .ci-tab-nav,
  .ci-toast,
  .ci-tooltip {
    display: none !important;
  }
  .ci-premium-card,
  .ci-premium-card--glass {
    background: white !important;
    border: 1px solid #ddd !important;
    backdrop-filter: none !important;
    box-shadow: none !important;
  }
  .ci-gradient-text,
  .ci-gradient-text--gold,
  .ci-gradient-text--success {
    -webkit-text-fill-color: currentColor !important;
    background: none !important;
  }
  .ci-achievement-card {
    border: 1px solid #ccc !important;
    background: white !important;
  }
  .ci-pro-match-card {
    border: 1px solid #ccc !important;
    background: white !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   v7.0 — REDUCED MOTION SUPPORT
   ═══════════════════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  .ci-tab-panel-active,
  .ci-pro-similarity-fill,
  .ci-mental-dim-fill,
  .ci-model-weight-fill,
  .ci-position-bar-fill,
  .ci-achievement-progress-fill,
  .ci-comparison-bar-fill,
  .ci-comparison-bar-ghost,
  .ci-gauge-container svg path.gauge-fill,
  .ci-progress-ring svg circle.progress-fill {
    transition: none;
    animation: none;
  }
  .ci-pro-match-card,
  .ci-pro-match-card:hover,
  .ci-ai-feature-card,
  .ci-ai-feature-card:hover,
  .ci-hover-lift,
  .ci-hover-lift:hover {
    transition: none;
    transform: none;
  }
  .ci-achievement-card:hover {
    transform: none;
  }
  .ci-form-dot:hover,
  .ci-form-strip-dot:hover {
    transform: none;
  }
  .ci-skeleton {
    animation: none;
    opacity: 0.7;
  }
  .ci-v7-orb,
  .ci-premium-ambient::before,
  .ci-premium-ambient::after {
    display: none;
  }
  .ci-toast {
    transition: none;
  }
  @keyframes ciTabFadeIn {
    from { opacity: 1; transform: none; }
    to   { opacity: 1; transform: none; }
  }
  @keyframes ciShimmer {
    from { background-position: 0 0; }
    to   { background-position: 0 0; }
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   V8.0 ENHANCED FEATURES — Performance Pulse, Training Load, Match Impact,
   Development Roadmap, Export/Share
   ═══════════════════════════════════════════════════════════════════════════ */

/* --- Performance Pulse --- */
.ci-pulse-section {
  margin-top: 28px;
}
.ci-pulse-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  margin-top: 16px;
}
.ci-pulse-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 16px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  position: relative;
  overflow: hidden;
  animation: ciPulseIn 0.4s ease both;
  animation-delay: var(--delay, 0s);
  transition: transform 0.2s, border-color 0.2s;
}
.ci-pulse-card:hover {
  transform: translateY(-3px);
  border-color: var(--accent);
}
.ci-pulse-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--accent);
  opacity: 0.6;
}
.ci-pulse-icon {
  font-size: 22px;
  line-height: 1;
}
.ci-pulse-data {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.ci-pulse-value {
  font-size: 24px;
  font-weight: 700;
  color: #fafafa;
}
.ci-pulse-label {
  font-size: 11px;
  color: #a1a1aa;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.ci-pulse-delta {
  display: flex;
  align-items: center;
  gap: 3px;
  font-size: 13px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 8px;
}
.ci-delta-up { color: #22c55e; background: rgba(34, 197, 94, 0.1); }
.ci-delta-down { color: #ef4444; background: rgba(239, 68, 68, 0.1); }
.ci-delta-flat { color: #f59e0b; background: rgba(245, 158, 11, 0.1); }
.ci-delta-arrow { font-size: 10px; }
.ci-pulse-prev {
  font-size: 10px;
  color: #71717a;
}
@keyframes ciPulseIn {
  from { opacity: 0; transform: translateY(12px) scale(0.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* --- Development Roadmap --- */
.ci-roadmap-section {
  margin-top: 28px;
}
.ci-roadmap-subtitle {
  color: #a1a1aa;
  font-size: 13px;
  margin: 4px 0 16px;
}
.ci-roadmap-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ci-roadmap-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 14px;
  padding: 16px;
  animation: ciPulseIn 0.4s ease both;
  animation-delay: var(--delay, 0s);
  transition: border-color 0.2s;
}
.ci-roadmap-item:hover {
  border-color: rgba(255, 255, 255, 0.15);
}
.ci-roadmap-rank {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}
.ci-roadmap-info {
  flex: 1;
  min-width: 0;
}
.ci-roadmap-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.ci-roadmap-attr {
  font-size: 15px;
  font-weight: 600;
  color: #fafafa;
  text-transform: capitalize;
  margin: 0;
}
.ci-roadmap-score {
  font-size: 13px;
  color: #a1a1aa;
  font-variant-numeric: tabular-nums;
}
.ci-roadmap-bar {
  height: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 10px;
}
.ci-roadmap-fill {
  height: 100%;
  width: var(--progress, 0%);
  background: var(--color, #6366f1);
  border-radius: 3px;
  transition: width 0.8s ease;
}
.ci-roadmap-drills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 6px;
}
.ci-roadmap-drill {
  font-size: 11px;
  color: #d4d4d8;
  background: rgba(99, 102, 241, 0.1);
  border: 1px solid rgba(99, 102, 241, 0.2);
  padding: 3px 10px;
  border-radius: 20px;
}
.ci-roadmap-eta {
  font-size: 11px;
  color: #71717a;
  font-style: italic;
}
.ci-roadmap-strengths {
  margin-top: 18px;
  padding: 14px 16px;
  background: rgba(34, 197, 94, 0.06);
  border: 1px solid rgba(34, 197, 94, 0.15);
  border-radius: 12px;
}
.ci-roadmap-strengths-title {
  font-size: 14px;
  color: #22c55e;
  margin: 0 0 10px;
}
.ci-roadmap-strengths-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ci-strength-tag {
  font-size: 12px;
  color: #d4d4d8;
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.2);
  padding: 4px 12px;
  border-radius: 20px;
}
.ci-strength-tag strong {
  color: #22c55e;
  margin-left: 4px;
}

/* --- Training Load Monitor --- */
.ci-load-section {
  margin-top: 28px;
}
.ci-load-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 24px;
  margin-top: 16px;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 20px 28px;
}
.ci-load-ratio-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  grid-row: 1 / 3;
}
.ci-load-ratio-ring {
  position: relative;
  width: 120px;
  height: 120px;
}
.ci-load-svg { width: 100%; height: 100%; }
.ci-load-ratio-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.ci-load-ratio-value {
  font-size: 28px;
  font-weight: 700;
  color: #fafafa;
}
.ci-load-ratio-label {
  font-size: 10px;
  text-transform: uppercase;
  color: #a1a1aa;
  letter-spacing: 1px;
}
.ci-load-zone {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 14px;
  border-radius: 20px;
  white-space: nowrap;
}
.ci-load-details {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ci-load-metric {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 8px;
  align-items: center;
}
.ci-load-metric-label {
  font-size: 12px;
  color: #a1a1aa;
}
.ci-load-metric-value {
  font-size: 16px;
  font-weight: 600;
  color: #fafafa;
  text-align: right;
}
.ci-load-metric-bar {
  grid-column: 1 / -1;
  height: 5px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
}
.ci-load-metric-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.8s ease;
}
.ci-load-sparkline {
  margin-top: 4px;
}
.ci-load-spark-label {
  font-size: 11px;
  color: #71717a;
  display: block;
  margin-bottom: 6px;
}
.ci-load-spark-svg {
  width: 100%;
  height: 60px;
  display: block;
}
.ci-load-zones-legend {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  padding-top: 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.ci-load-zone-item {
  font-size: 10px;
  color: var(--zc);
  opacity: 0.7;
}
.ci-load-zone-item.ci-zone-active {
  opacity: 1;
  font-weight: 600;
}

/* --- Match Impact Ratings --- */
.ci-impact-section {
  margin-top: 28px;
}
.ci-impact-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}
.ci-impact-row {
  display: grid;
  grid-template-columns: 36px 1fr auto 100px auto auto;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  animation: ciPulseIn 0.35s ease both;
  animation-delay: var(--delay, 0s);
  transition: border-color 0.2s, background 0.2s;
}
.ci-impact-row:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.12);
}
.ci-impact-result {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.ci-impact-W { background: rgba(34, 197, 94, 0.25); color: #22c55e; }
.ci-impact-D { background: rgba(245, 158, 11, 0.25); color: #f59e0b; }
.ci-impact-L { background: rgba(239, 68, 68, 0.25); color: #ef4444; }
.ci-impact-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.ci-impact-opponent {
  font-size: 13px;
  font-weight: 500;
  color: #fafafa;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ci-impact-date {
  font-size: 11px;
  color: #71717a;
}
.ci-impact-stats {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ci-impact-stat {
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 6px;
  white-space: nowrap;
}
.ci-is-goal { background: rgba(245, 158, 11, 0.15); color: #f59e0b; }
.ci-is-assist { background: rgba(34, 197, 94, 0.15); color: #22c55e; }
.ci-is-rating { background: rgba(99, 102, 241, 0.15); color: #818cf8; }
.ci-impact-bar-wrap { display: flex; align-items: center; }
.ci-impact-bar {
  width: 100%;
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
}
.ci-impact-fill {
  height: 100%;
  width: var(--progress, 0%);
  background: var(--color, #6366f1);
  border-radius: 3px;
  transition: width 0.6s ease;
}
.ci-impact-score-badge {
  font-size: 14px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 8px;
  text-align: center;
  min-width: 36px;
}
.ci-impact-tier {
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
}
.ci-impact-avg {
  margin-top: 14px;
  padding: 12px 16px;
  background: rgba(99, 102, 241, 0.08);
  border: 1px solid rgba(99, 102, 241, 0.15);
  border-radius: 10px;
  text-align: center;
  font-size: 14px;
  color: #d4d4d8;
}
.ci-impact-avg strong {
  color: #fafafa;
  font-size: 18px;
  margin: 0 2px;
}
.ci-impact-empty {
  padding: 32px;
  text-align: center;
  color: #71717a;
  font-size: 14px;
}

/* --- Export & Share Buttons --- */
.ci-footer-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-bottom: 16px;
}
.ci-export-btn,
.ci-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #fafafa;
}
.ci-export-btn {
  background: rgba(99, 102, 241, 0.15);
  border-color: rgba(99, 102, 241, 0.3);
}
.ci-export-btn:hover {
  background: rgba(99, 102, 241, 0.25);
  transform: translateY(-1px);
}
.ci-share-btn {
  background: rgba(34, 197, 94, 0.15);
  border-color: rgba(34, 197, 94, 0.3);
}
.ci-share-btn:hover {
  background: rgba(34, 197, 94, 0.25);
  transform: translateY(-1px);
}

/* --- v8.0 Responsive --- */
@media (max-width: 768px) {
  .ci-pulse-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .ci-load-card {
    grid-template-columns: 1fr;
  }
  .ci-load-ratio-container {
    grid-row: auto;
    flex-direction: row;
    justify-content: center;
    gap: 16px;
  }
  .ci-impact-row {
    grid-template-columns: 32px 1fr auto;
    gap: 8px;
  }
  .ci-impact-stats,
  .ci-impact-bar-wrap,
  .ci-impact-tier {
    display: none;
  }
  .ci-roadmap-item {
    flex-direction: column;
    align-items: stretch;
  }
}
@media (max-width: 500px) {
  .ci-pulse-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .ci-pulse-card {
    padding: 12px 10px;
  }
  .ci-pulse-value {
    font-size: 20px;
  }
  .ci-load-ratio-ring {
    width: 100px;
    height: 100px;
  }
  .ci-load-ratio-value {
    font-size: 22px;
  }
  .ci-footer-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .ci-export-btn,
  .ci-share-btn {
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   v9.0 — PHYSICAL FITNESS PROFILE (Overview Tab)
   ═══════════════════════════════════════════════════════════════════════════ */

.ci-physical-profile-section {
  margin-top: 24px;
}

.ci-phys-profile-grid {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 24px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  padding: 24px;
  margin-top: 12px;
}

.ci-phys-radar-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
}

.ci-phys-radar {
  width: 100%;
  max-width: 220px;
  height: auto;
}

.ci-phys-details {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ci-phys-dims {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ci-phys-dim-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ci-phys-dim-label {
  width: 80px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}

.ci-phys-dim-bar {
  flex: 1;
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
}

.ci-phys-dim-fill {
  height: 100%;
  width: 0;
  border-radius: 3px;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.ci-phys-dim-val {
  width: 28px;
  text-align: right;
  font-size: 12px;
  font-weight: 700;
  color: #fafafa;
  flex-shrink: 0;
}

.ci-phys-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.ci-phys-meta-item {
  flex: 1;
  min-width: 90px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 10px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ci-phys-meta-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #71717a;
  font-weight: 600;
}

.ci-phys-meta-value {
  font-size: 15px;
  font-weight: 700;
  color: #fafafa;
}

.ci-phys-meta-value small {
  font-size: 10px;
  font-weight: 500;
  opacity: 0.7;
  margin-left: 4px;
}

.ci-phys-sw-label {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #71717a;
  font-weight: 600;
  margin-bottom: 6px;
}

.ci-phys-sw-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.ci-phys-str-tag {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  background: rgba(16, 185, 129, 0.12);
  color: #10b981;
  border: 1px solid rgba(16, 185, 129, 0.2);
}

.ci-phys-weak-tag {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  background: rgba(245, 158, 11, 0.12);
  color: #f59e0b;
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.ci-phys-modifier-note {
  font-size: 12px;
  color: #a1a1aa;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 8px;
  border-left: 3px solid #f59e0b;
}

.ci-phys-modifier-note strong {
  font-weight: 700;
}

.ci-phys-footer {
  margin-top: 12px;
  font-size: 11px;
  color: #52525b;
  text-align: center;
}

/* Physical Profile Empty State */
.ci-phys-empty {
  text-align: center;
  padding: 40px 24px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px dashed rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  margin-top: 12px;
}

.ci-phys-empty-icon {
  margin-bottom: 16px;
  opacity: 0.3;
}

.ci-phys-empty-icon svg {
  stroke: #71717a;
}

.ci-phys-empty-title {
  font-size: 16px;
  font-weight: 700;
  color: #fafafa;
  margin-bottom: 8px;
}

.ci-phys-empty-desc {
  font-size: 13px;
  color: #71717a;
  max-width: 400px;
  margin: 0 auto 20px;
  line-height: 1.5;
}

.ci-phys-empty-cta {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #000;
  border: none;
  padding: 10px 24px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}

.ci-phys-empty-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(245, 158, 11, 0.3);
}

/* Physical Profile Responsive */
@media (max-width: 640px) {
  .ci-phys-profile-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 16px;
  }
  .ci-phys-radar-wrap {
    max-width: 200px;
    margin: 0 auto;
  }
  .ci-phys-meta-row {
    gap: 8px;
  }
  .ci-phys-meta-item {
    min-width: 70px;
    padding: 8px 10px;
  }
}
