/* ================================
   01-VISION-PAGE.CSS
   XHELOS 3 Vision Page Specific Styles
   ================================ */

/* #region ===== GLOBAL PAGE STYLES ===== */

.vision-container {
    width: 100%;
    min-height: 100vh;
    background: var(--bg-primary);
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-xl);
}

.section-title {
    font-size: 2.5rem;
    text-align: center;
    margin-bottom: var(--space-lg);
    background: linear-gradient(90deg, var(--accent-bio), var(--accent-crystal));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.section-description {
    text-align: center;
    color: var(--text-secondary);
    font-size: 1.1rem;
    margin-bottom: var(--space-xl);
    /*background: #3d1b40;*/
    padding: 0.3rem;
    border-radius: 2rem;
}

/* #endregion */

/* #region ===== HERO SECTION ===== */

.hero-section {
    /*min-height: 65vh;*/
    margin-top:var(--space-2xl);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: linear-gradient(135deg,
        var(--bg-primary) 0%,
        rgba(74, 222, 128, 0.1) 50%,
        var(--bg-primary) 100%);
    cursor: pointer;
    transition: all 0.3s ease;
}



.hero-background {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-background .particle {
    position: absolute;
    width: 4px;
    height: 4px;
    background: var(--accent-bio);
    border-radius: 50%;
    animation: floatParticle 20s infinite linear;
    opacity: 0.5;
}

.hero-background .particle:nth-child(1) {
    top: 20%;
    left: 10%;
    animation-delay: 0s;
}

.hero-background .particle:nth-child(2) {
    top: 60%;
    left: 80%;
    animation-delay: 5s;
    background: var(--accent-crystal);
}

.hero-background .particle:nth-child(3) {
    top: 80%;
    left: 30%;
    animation-delay: 10s;
    background: var(--accent-psi);
}

@keyframes floatParticle {
    0% {
        transform: translate(0, 0) rotate(0deg);
    }
    25% {
        transform: translate(100px, -100px) rotate(90deg);
    }
    50% {
        transform: translate(-50px, -200px) rotate(180deg);
    }
    75% {
        transform: translate(-150px, -100px) rotate(270deg);
    }
    100% {
        transform: translate(0, 0) rotate(360deg);
    }
}

.hero-content {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: var(--space-xl);
}

.hero-title {
font-size: clamp(2.5rem, 9.5vw, 7.5rem);
  margin: 0;
  font-weight: 900;
  letter-spacing: -0.02em;
  font-family: var(--font-heading);
}

/* Glitch Effect */
.glitch {
    position: relative;
    color: var(--text-primary);
    text-shadow: 
        0 0 10px var(--accent-bio),
        0 0 20px var(--accent-bio),
        0 0 40px var(--accent-bio);
}

.glitch::before,
.glitch::after {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.glitch::before {
    animation: glitch-1 0.5s infinite;
    color: var(--accent-crystal);
    z-index: -1;
}

.glitch::after {
    animation: glitch-2 0.5s infinite;
    color: var(--accent-chem);
    z-index: -2;
}

@keyframes glitch-1 {
    0%, 100% {
        clip-path: inset(0 0 0 0);
        transform: translate(0);
    }
    20% {
        clip-path: inset(20% 0 40% 0);
        transform: translate(-2px, 2px);
    }
}

@keyframes glitch-2 {
    0%, 100% {
        clip-path: inset(0 0 0 0);
        transform: translate(0);
    }
    20% {
        clip-path: inset(60% 0 20% 0);
        transform: translate(2px, -2px);
    }
}

.hero-subtitle {
    font-size: 1.5rem;
    color: var(--text-secondary);
    margin: var(--space-lg) 0;
    animation-delay: 0.5s;
}

.hero-cta {
    margin-top: var(--space-xl);
    animation-delay: 1.5s;
}

/* Cinematic Trigger Button */
.cinematic-trigger {
    margin: var(--space-2xl) 0;
    animation-delay: 1s;
}

.btn-cinematic {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-lg) var(--space-2xl);
    background: linear-gradient(135deg, var(--accent-bio), var(--accent-crystal));
    border: 2px solid transparent;
    border-radius: var(--radius-full);
    color: var(--bg-primary);
    font-size: 1.2rem;
    font-weight: 700;
    cursor: pointer;
    transition: all var(--transition-normal);
    overflow: hidden;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-family: inherit;
}

.btn-cinematic::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.btn-cinematic:hover::before {
    width: 300px;
    height: 300px;
}

.btn-cinematic:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(74, 222, 128, 0.5);
}

.play-icon {
    font-size: 1.5rem;
    animation: pulse 2s infinite;
}

.play-text {
    font-size: 1rem;
}

.cinematic-hint {
    margin-top: var(--space-md);
    font-size: 0.9rem;
    color: var(--text-secondary);
    font-style: italic;
}

/* Cinematic Container */
.cinematic-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.95);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.5s ease;
}

.cinematic-container:not(.hidden) {
    opacity: 1;
    visibility: visible;
}

/* #endregion */

/* #region ===== EPIC HOOK SECTION ===== */

.epic-hook-section {
    padding: var(--space-xl) var(--space-3xl);
    background: var(--bg-secondary);
    text-align: center;
}
.epic-hook-section h1{
    margin-top:0px;
}
.epic-tagline {
    font-size: clamp(2rem, 5vw, 4rem);
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.epic-tagline .line {
    display: block;
    margin: var(--space-md) 0;
    background: linear-gradient(90deg, 
        var(--accent-bio), 
        var(--accent-crystal), 
        var(--accent-psi));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.sub-tagline {
    font-size: 1.25rem;
    color: var(--text-secondary);
    margin: var(--space-xl) 0;
    font-style: italic;
}

.game-comparison {
    margin-top: var(--space-2xl);
}

.comparison-badge {
    display: inline-block;
    padding: var(--space-md) var(--space-xl);
    background: var(--bg-tertiary);
    border: 2px solid var(--border);
    border-radius: var(--radius-full);
    font-size: 1.1rem;
}

.game-ref {
    color: var(--accent-bio);
    font-weight: bold;
    padding: 0 var(--space-xs);
}

/* #endregion */

/* #region ===== FOUR PILLARS ===== */

.pillars-section {
    /**padding: var(--space-3xl) 0;*/
    background: var(--bg-primary);
}

.pillars-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-xl);
    margin-top: var(--space-2xl);
}

.pillar-card {
    min-height: 400px;
    display: flex;
    flex-direction: column;
}

.pillar-card .card__icon {
    font-size: 3rem;
    margin-bottom: var(--space-md);
    text-align: center;
}

.pillar-card .feature-list {
    list-style: none;
    padding: 0;
    margin: var(--space-md) 0;
}

.pillar-card .feature-list li {
    padding: var(--space-xs) 0;
    padding-left: 1.5rem;
    position: relative;
}

.pillar-card .feature-list li::before {
    content: "▸";
    position: absolute;
    left: 0;
    color: currentColor;
}

/* #endregion */
/* #region ===== COMBAT FLOW ===== */



.effects-cascade {
    margin-top: var(--space-2xl);
    padding: var(--space-xl);
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
}

.cascade-timeline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: var(--space-lg);
    padding: var(--space-lg);
    background: var(--bg-tertiary);
    border-radius: var(--radius-md);
}

.cascade-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-sm);
}

.effect-icon {
    font-size: 2rem;
}

.effect-name {
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.cascade-arrow {
    font-size: 1.5rem;
    color: var(--accent-tech);
    animation: pulse 2s infinite;
}

/* #endregion */

/* #region ===== SCALE DEMONSTRATION ===== */

.scale-zoom-container {
    margin-top: var(--space-2xl);
}

.zoom-controls {
    display: flex;
    justify-content: center;
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
    flex-wrap: wrap;
}

.zoom-btn {
    padding: var(--space-sm) var(--space-md);
    background: var(--bg-tertiary);
    border: 2px solid var(--border);
    color: var(--text-primary);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    font-family: inherit;
}

.zoom-btn:hover {
    border-color: var(--accent-bio);
    transform: translateY(-2px);
}

.zoom-btn.active {
    background: var(--accent-bio);
    color: var(--bg-primary);
    border-color: var(--accent-bio);
}

.zoom-viewport {
    position: relative;
    height: 500px;
    background: var(--bg-primary);
    border: 2px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.zoom-level {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-normal);
}

.zoom-level.active {
    opacity: 1;
    visibility: visible;
}

.level-content {
    text-align: center;
}

.level-content h3 {
    font-size: 2rem;
    margin-bottom: var(--space-md);
    color: var(--accent-bio);
}

.unit-icon {
    font-size: 5rem;
}



/* #endregion */

/* #region ===== ALLIANCE SYSTEM ===== */

.role-card {
    background: var(--bg-secondary);
    border: 2px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    text-align: center;
    min-width: 150px;
    transition: all var(--transition-fast);
}


.role-card h4 {
    margin: var(--space-sm) 0;
    color: var(--text-primary);
}

.role-card p {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin: 0;
}



.level-leader .role-card {
    border-color: var(--accent-tech);
    background: rgba(245, 158, 11, 0.1);
}

.level-propagator .role-card {
    border-color: var(--accent-psi);
    background: rgba(167, 139, 250, 0.1);
}

/* #endregion */

/* #region ===== RESOURCE ECONOMY ===== */
.normal-section {
    margin-top: 5rem;
}

.resource-layers {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-xl);
    margin: 0 0;
}
.resource-layers h3{
    margin-bottom:1.5rem;
}

.resource-display {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-sm) 0;
    border-bottom: 1px solid var(--border);
}

.resource-display:last-child {
    border-bottom: none;
}

.resource-icon {
    font-size: 1.5rem;
}

.resource-name {
    font-weight: 600;
    flex: 1;
}

.resource-desc {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

/* #endregion */

/* #region ===== FACTIONS ===== */


.faction-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(185px, 1fr));
    gap: var(--space-lg);
    margin-top: var(--space-2xl);
}

.faction-card {
    background: var(--bg-secondary);
    border: 2px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    text-align: center;
}

.faction-icon {
    font-size: 3rem;
    display: block;
    margin-bottom: var(--space-md);
    width: 100%;
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.faction-icon img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.faction-name {
    font-size: 1.2rem;
    margin-bottom: var(--space-sm);
    color: var(--text-primary);
}

.faction-desc {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: var(--space-md);
    line-height: 1.4;
}

/* #endregion */

/* #region ===== PLAYER JOURNEY - ZIGZAG TIMELINE ===== */

/* Journey Timeline Container */
.journey-timeline {
    position: relative;
    padding: 3rem 2rem;
    max-width: 1200px;
    margin: 0 auto;
}

/* Central vertical line */
.journey-timeline::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(
        180deg,
        var(--accent-bio) 0%,
        var(--accent-crystal) 25%,
        var(--accent-tech) 50%,
        var(--accent-psi) 75%,
        #dc2626 100%
    );
    transform: translateX(-50%);
    z-index: 1;
}

/* Journey Item Container */
.journey-item {
    position: relative;
    display: flex;
    align-items: center;
    margin: 1rem 0;
    width: 100%;
}

/* Journey Node (numbered circle) */
.journey-node {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 50px;
    height: 50px;
    background: var(--bg-secondary);
    border: 3px solid var(--border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 1.2rem;
    z-index: 3;
    transition: all var(--transition-fast);
}

/* Journey Connector (horizontal line) */
.journey-connector {
    position: absolute;
    top: 50%;
    width: 50%;
    height: 2px;
    background: var(--border);
    z-index: 0;
}

/* Journey Content Box */
.journey-content {
    position: relative;
    background: var(--bg-secondary);
    border: 2px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    width: 42%;
}

.journey-content h4 {
    color: var(--text-primary);
    margin: 0 0 0.5rem;
    font-size: 1.1rem;
}

.journey-content p {
    color: var(--text-secondary);
    margin: 0;
    font-size: 0.95rem;
}

/* Left side items (odd) */
.journey-item:nth-child(odd) {
    justify-content: flex-start;
}

.journey-item:nth-child(odd) .journey-content {
    margin-right: auto;
}

.journey-item:nth-child(odd) .journey-connector {
    left: 42%;
    transform: translateX(0);
}

/* Right side items (even) */
.journey-item:nth-child(even) {
    justify-content: flex-end;
}

.journey-item:nth-child(even) .journey-content {
    margin-left: auto;
}

.journey-item:nth-child(even) .journey-connector {
    right: 42%;
    left: auto;
}

/* Color progression for nodes */
.journey-item:nth-child(1) .journey-node {
    border-color: var(--accent-bio);
    color: var(--accent-bio);
}

.journey-item:nth-child(2) .journey-node {
    border-color: var(--accent-crystal);
    color: var(--accent-crystal);
}

.journey-item:nth-child(3) .journey-node {
    border-color: var(--accent-tech);
    color: var(--accent-tech);
}

.journey-item:nth-child(4) .journey-node {
    border-color: var(--accent-psi);
    color: var(--accent-psi);
}

.journey-item:nth-child(5) .journey-node {
    border-color: #ef4444;
    color: #ef4444;
}

.journey-item:nth-child(6) .journey-node {
    border-color: #dc2626;
    color: #dc2626;
    background: linear-gradient(135deg, var(--bg-secondary), rgba(220, 38, 38, 0.1));
}

/* Responsive Design */
@media (max-width: 768px) {
    .journey-timeline {
        padding: 2rem 1rem;
    }

    .journey-timeline::before {
        left: 30px;
    }

    .journey-item {
        margin: 2rem 0;
        justify-content: flex-start !important;
    }

    .journey-node {
        left: 30px;
        width: 40px;
        height: 40px;
        font-size: 1rem;
    }

    .journey-connector {
        display: none;
    }

    .journey-content {
        width: calc(100% - 70px);
        margin-left: 70px !important;
        margin-right: 0 !important;
    }

    .journey-content h4 {
        font-size: 1rem;
    }

    .journey-content p {
        font-size: 0.9rem;
    }
}

/* #endregion */

/* #region ===== PLAYER JOURNEY ===== */


.memory-fragment {
    background: var(--bg-tertiary);
    border: 2px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    margin: var(--space-lg) 0;
    position: relative;
    transition: all var(--transition-fast);
}

.memory-fragment:hover {
    border-color: var(--accent-bio);
    transform: translateX(10px);
}

.fragment-time {
    position: absolute;
    top: -10px;
    left: var(--space-lg);
    background: var(--bg-secondary);
    padding: var(--space-xs) var(--space-md);
    border: 2px solid var(--accent-bio);
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    font-weight: bold;
    color: var(--accent-bio);
}

.fragment-content h4 {
    color: var(--text-primary);
    margin-bottom: var(--space-sm);
}

.fragment-content p {
    color: var(--text-secondary);
    font-size: 0.9rem;
}

/* #endregion */

/* #region ===== THE STAKES ===== */


.corruption-meter {
    margin-top: var(--space-lg);
    height: 30px;
    background: var(--bg-secondary);
    border: 2px solid var(--accent-chem);
    border-radius: var(--radius-full);
    overflow: hidden;
    position: relative;
}

.corruption-fill {
    height: 100%;
    width: 30%;
    background: linear-gradient(90deg, 
        var(--accent-chem), 
        #ff0000);
    transition: width 0.5s ease;
}

.corruption-label {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 0.85rem;
    font-weight: bold;
    color: white;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.8);
    white-space: nowrap;
}

.endings-preview {
    margin-top: var(--space-2xl);
}

.endings-preview h3 {
    text-align: center;
    color: var(--text-primary);
    margin-bottom: var(--space-lg);
}

.endings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--space-md);
    margin-top: var(--space-lg);
}

.ending-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    text-align: center;
    transition: all var(--transition-fast);
    cursor: pointer;
}

.ending-card:hover {
    border-color: var(--accent-chem);
    background: rgba(236, 72, 153, 0.1);
    transform: scale(1.05);
}

.ending-card h4 {
    margin: var(--space-sm) 0 0 0;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.ending-icon {
    font-size: 2rem;
    display: block;
    margin-bottom: var(--space-sm);
}

/* #endregion */

/* #region ===== FINAL CTA ===== */

.cta-section {
    background: linear-gradient(135deg,var(--bg-secondary), rgba(74, 222, 128, 0.1));
    padding: var(--space-2xl);
}
.cta-section h2{
    margin-top:0px;
}
.cta-box {
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.cta-title {
    font-size: 3rem;
    margin-bottom: var(--space-lg);
    color: var(--text-primary);
}

.cta-description {
    font-size: 1.25rem;
    color: var(--text-secondary);
    margin-bottom: var(--space-2xl);
}

.cta-buttons {
    display: flex;
    gap: var(--space-lg);
    justify-content: center;
    flex-wrap: wrap;
}

/* #endregion */

/* #region ===== UTILITIES ===== */

/* Back to Top Button */
.back-to-top {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 50px;
    height: 50px;
    background: var(--accent-bio);
    color: var(--bg-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-fast);
    z-index: 1000;
    border: none;
}

.back-to-top.visible {
    opacity: 1;
    visibility: visible;
}

.back-to-top:hover {
    transform: translateY(-5px);
    box-shadow: 0 5px 15px rgba(74, 222, 128, 0.4);
}

/* Info Box (reused from base) */
.info-box {
    background: var(--bg-tertiary);
    border-left: 4px solid var(--accent-bio);
    padding: var(--space-md);
    margin: var(--space-lg) 0;
    border-radius: var(--radius-sm);
}

/* #endregion */

/* #region ===== RESPONSIVE ===== */

@media (max-width: 1024px) {
    .builder-showcase {
        grid-template-columns: 1fr;
    }
    
    .pillars-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .resource-layers {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .container {
        padding: 0 var(--space-md);
    }
    
    .hero-title {
        font-size: 3rem;
    }
    
    .epic-tagline {
        font-size: 2rem;
    }
    
    .epic-tagline .line {
        font-size: 1.5rem;
    }
    
    .section-title {
        font-size: 1.8rem;
    }
    
    .pillars-grid {
        grid-template-columns: 1fr;
    }
    
    .cascade-timeline {
        flex-direction: column;
        gap: var(--space-lg);
    }
    
    .cascade-arrow {
        transform: rotate(90deg);
    }
    
    .zoom-controls {
        gap: var(--space-sm);
    }
    
    .zoom-btn {
        padding: var(--space-xs) var(--space-sm);
        font-size: 0.9rem;
    }
    
    .faction-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .endings-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .cta-title {
        font-size: 2rem;
    }
    
    .back-to-top {
        width: 40px;
        height: 40px;
        font-size: 1.2rem;
    }
}

@media (max-width: 480px) {
    .faction-grid {
        grid-template-columns: 1fr;
    }
    
    .parts-grid {
        grid-template-columns: 1fr;
    }
    
    .stat-display {
        grid-template-columns: 1fr;
    }
    
    .cta-buttons {
        flex-direction: column;
        width: 100%;
    }
    
    .cta-buttons .btn {
        width: 100%;
    }
}

/* #endregion */

/* Skip button for cinematic */
.cinematic-skip-btn {
    position: fixed;
    top: 30px;
    right: 30px;
    z-index: 10000;
    background: rgba(0, 0, 0, 0.7);
    border: 2px solid var(--accent-bio);
    color: var(--accent-bio);
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    font-family: inherit;
}

.cinematic-skip-btn:hover {
    background: var(--accent-bio);
    color: var(--bg-primary);
}

.cinematic-skip-btn small {
    display: block;
    font-size: 0.8rem;
    opacity: 0.8;
    margin-top: 2px;
}
/* ================================
   FOUR PILLARS/ROLES STYLES - ENHANCED VERSION
   ================================ */

/* ===== SHARED STYLES ===== */
.section-dark-subtitle {
    
    color: var(--text-secondary);
    font-style: italic;
    margin-bottom: var(--space-2xl);
    font-size: 1.1rem;
    opacity: 0.8;
}

/* ===== PILLARS VERSION - Enhanced Cards ===== */
.pillars-version .pillars-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-xl);
    margin-top: var(--space-xl);
}

@media (max-width: 768px) {
    .pillars-version .pillars-container {
        grid-template-columns: 1fr;
    }
}

.pillars-version .role-card {
    background: var(--bg-secondary);
    border: 2px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    position: relative;
    overflow: hidden;
}

/* Add subtle gradient background based on role color */
.pillars-version .role-card::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    background: linear-gradient(90deg, transparent, currentColor);
    opacity: 0.03;
    pointer-events: none;
}

/* Role-specific colors */
.pillars-version .role--mutator {
    border-color: var(--accent-bio);
    color: var(--accent-bio);
}

.pillars-version .role--strategist {
    border-color: var(--accent-crystal);
    color: var(--accent-crystal);
}

.pillars-version .role--conqueror {
    border-color: var(--accent-tech);
    color: var(--accent-tech);
}

.pillars-version .role--ideologue {
    border-color: var(--accent-psi);
    color: var(--accent-psi);
}

/* New header layout with icon on left */
.pillars-version .role-header {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    margin-bottom: var(--space-md);
    /*padding-bottom: var(--space-lg);*/
    border-bottom: 1px solid var(--border);
}

.pillars-version .role-icon {
    font-size: 3.5rem;
    flex-shrink: 0;
}

.pillars-version .role-info {
    flex: 1;
}

.pillars-version .role-title {
    font-size: 1.5rem;
    margin: 0 0 var(--space-xs) 0;
    color: currentColor;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-align: left;
}

.pillars-version .role-tagline {
    font-style: italic;
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.3;
    margin: 0;
    text-align: left;
}

/* Features with numbered bullets */
.pillars-version .role-features {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    counter-reset: feature-counter;
}

.pillars-version .feature-item {
    font-size: 0.9rem;
    line-height: 1.4;
    color: var(--text-primary);
    background: var(--bg-tertiary);
    padding: var(--space-sm) var(--space-md);
    padding-left: calc(var(--space-md) + 2rem);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    position: relative;
    counter-increment: feature-counter;
    text-align: left;
}

/* Numbered circle */
.pillars-version .feature-item::before {
    content: counter(feature-counter);
    position: absolute;
    left: var(--space-sm);
    top: 50%;
    transform: translateY(-50%);
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 50%;
    background: currentColor;
    color: var(--bg-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 700;
}

/* Color the number based on parent card */
.pillars-version .role--mutator .feature-item::before {
    background: var(--accent-bio);
}

.pillars-version .role--strategist .feature-item::before {
    background: var(--accent-crystal);
}

.pillars-version .role--conqueror .feature-item::before {
    background: var(--accent-tech);
}

.pillars-version .role--ideologue .feature-item::before {
    background: var(--accent-psi);
}

.pillars-version .feature-item strong {
    color: inherit;
    font-weight: 600;
}

/* Optional: Add a subtle border glow matching the role color */
.pillars-version .role-card {
    box-shadow: inset 0 0 0 1px currentColor;
    opacity: 0.95;
}

/* Optional: Role number in corner */
.pillars-version .role-card {
    counter-increment: role-counter;
}

.pillars-version .pillars-container {
    counter-reset: role-counter;
}

.pillars-version .role-number {
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    border: 2px solid currentColor;
    color: currentColor;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    opacity: 0.3;
}

/* ================================
   SISTEMA DE CONSTRUCCIÓN MODULAR - NUEVO LAYOUT
   ================================ */

/* Contenedor de cards */
.modular-showcase-cards {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    margin-top: 0rem;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
}

/* Card block base */
.showcase-card-block {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 0rem;
}

/* Header con icono y título */
.showcase-card-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.5rem 1rem;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border);
}

/* Icono */
.showcase-card-icon {
    min-width: 64px;
    height: 64px;
    background: var(--bg-secondary);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    flex-shrink: 0;
}

.showcase-card-icon .card-icon {
    font-size: 2rem;
}

/* Títulos */
.showcase-card-titles {
    flex: 1;
}

.showcase-card-title {
    /*font-size: 1.5rem;*/
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: var(--accent-bio);
    margin-top: 0.5rem;
}

.showcase-card-subtitle {
    color: var(--text-secondary);
    font-style: italic;
    font-size: 1rem;
}

/* Body con contenido completo */
.showcase-card-body {
    padding: 1.5rem 1.5rem 2rem;
}
.showcase-card-body h4{
    margin:0px 0px 0.5rem;
}

/* Features list */
.showcase-card-features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.showcase-card-features li {
    color: var(--text-secondary);
    line-height: 1.6;
    padding-left: 1.5rem;
    position: relative;
}

.showcase-card-features li::before {
    content: "▸";
    position: absolute;
    left: 0;
    color: currentColor;
}

.showcase-card-features li strong {
    color: inherit;
}

/* Texto largo para estrategias */
.showcase-card-text {
    color: var(--text-secondary);
    line-height: 1.7;
    font-size: 1rem;
}

.showcase-card-text p {
    margin: 0;
}

/* Nota en cursiva */
.showcase-card-note {
    margin-top: 1.5rem;
    padding: 1rem 1.5rem;
    background: var(--bg-tertiary);
    border-left: 3px solid currentColor;
    border-radius: var(--radius-sm);
    font-style: italic;
    line-height: 1.6;
    opacity: 0.9;
    margin-bottom: 0px;

}

/* Un solo color verde para todos los títulos y elementos en sección 1.3 */
.constructor-section .showcase-card-title,
.constructor-section .showcase-card-features li strong,
.constructor-section .showcase-card-features li::before,
.constructor-section .showcase-card-note,
.constructor-section .showcase-card-note em,
.constructor-section h4,
.constructor-section .strategy-subtitle {
    color: var(--accent-bio) !important;
}

/* Mantener los fondos de los iconos con variación sutil */
.constructor-section .showcase-card-icon {
    background: linear-gradient(135deg, var(--bg-secondary), rgba(74, 222, 128, 0.1));
}

/* Responsive */
@media (max-width: 768px) {
    .showcase-card-header {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
    }
    
    .showcase-card-icon {
        margin: 0 auto;
    }
    
    .showcase-card-body {
        padding: 1.5rem;
    }
    
    .showcase-card-features li {
        font-size: 0.95rem;
    }
}

@media (max-width: 480px) {
    .showcase-card-header {
        padding: 1.5rem;
    }
    
    .showcase-card-body {
        padding: 1rem;
    }
    
    .showcase-card-title {
        font-size: 1.2rem;
    }
    
    .showcase-card-features li {
        font-size: 0.9rem;
        padding-left: 1rem;
    }
}



/* ================================
   ROLES TEMÁTICOS
   ================================ */

/* Badge del rol */
.role-badge {
    display: inline-block;
    margin-left: 1rem;
    padding: 0.3rem 0.8rem;
    border-radius: 2rem;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    vertical-align: middle;
}

/* ROLE SECTIONS - Common styles */
.role-section {
    position: relative;
    padding-left: 2rem;
    margin-top: 5rem;
}

/* THE MUTATOR THEME */
.role-section-mutator {
    background: linear-gradient(180deg, transparent, rgba(74, 222, 128, 0.02));
    border-left: 4px solid var(--accent-bio);
}

.role-section-mutator h2 {
    color: var(--accent-bio);
}

.role-section-mutator .role-badge {
    background: var(--accent-bio);
    color: var(--text-tertiary);
}

.role-section-mutator .section-description {
    background: #1b3d26; /* Pastel green based on bio theme */
}

/* THE STRATEGIST THEME */
.role-section-strategist {
    background: linear-gradient(180deg, transparent, rgba(96, 165, 250, 0.02));
    border-left: 4px solid var(--accent-crystal);
}

.role-section-strategist h2 {
    color: var(--accent-crystal);
}

.role-section-strategist .role-badge {
    background: var(--accent-crystal);
    color: var(--text-tertiary);
}

.role-section-strategist .section-description {
    background: #1b2d3d; /* Pastel blue based on crystal theme */
}

/* THE CONQUEROR THEME */
.role-section-conqueror {
    background: linear-gradient(180deg, transparent, rgba(245, 158, 11, 0.02));
    border-left: 4px solid var(--accent-tech);
}

.role-section-conqueror h2 {
    color: var(--accent-tech);
}

.role-section-conqueror .role-badge {
    background: var(--accent-tech);
    color: var(--text-tertiary);
}

.role-section-conqueror .section-description {
    background: #3d2b1b; /* Pastel orange/brown based on tech theme */
}

/* THE IDEOLOGUE THEME */
.role-section-ideologue {
    background: linear-gradient(180deg, transparent, rgba(167, 139, 250, 0.02));
    border-left: 4px solid var(--accent-psi);
}

.role-section-ideologue h2 {
    color: var(--accent-psi);
}

.role-section-ideologue .role-badge {
    background: var(--accent-psi);
    color: var(--text-tertiary);
}

.role-section-ideologue .section-description {
    background: #3d1b40; /* Pastel purple/pink based on psi theme */
}

/* Responsive */
@media (max-width: 768px) {
    .role-badge {
        display: block;
        margin: 0.5rem 0;
        width: fit-content;
    }
    
    .role-section {
        padding-left: 1rem;
    }

}

/* ================================
   ACCORDION OVERRIDES FOR SHOWCASE CARDS
   ================================ */
.showcase-card-block.accordion-item {
    background: transparent;
    border: none;
    
}

.showcase-card-header.accordion-header {
    background: var(--bg-tertiary);
    padding: 0.5rem 1rem;
    border-bottom: 1px solid var(--border);
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    display: flex;
    align-items: center;
    gap: 1rem;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.showcase-card-header.accordion-header:hover {
    background: var(--bg-secondary);
}

/* Icon container styling */
.showcase-card-icon {
    min-width: 64px;
    height: 64px;
    background: var(--bg-secondary);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    flex-shrink: 0;
}

.showcase-card-icon .card-icon {
    font-size: 2rem;
}

.showcase-card-block .accordion-content {
    
    border-top: none;
}

.showcase-card-block .accordion-content-inner {
    padding: 0;
}

.showcase-card-block .accordion-icon {
    margin-left: auto;
    font-size: 1.5rem;
    color: var(--text-secondary);
    opacity: 0.6;
    transition: all 0.3s ease;
}

.showcase-card-block.active .accordion-icon {
    opacity: 1;
}

/* Maintain showcase card styling for headers */
.showcase-card-block .showcase-card-titles {
    flex: 1;
}



.showcase-card-subtitle {
    color: var(--text-secondary);
    font-style: italic;
    font-size: 1rem;
}

/* Color azul solo para los títulos principales en sección 1.4 */
.combat-section .showcase-card-title {
    color: var(--accent-crystal) !important;
}

/* Mantener los fondos de los iconos con variación sutil en azul */
.combat-section .showcase-card-icon {
    background: linear-gradient(135deg, var(--bg-secondary), rgba(96, 165, 250, 0.1));
}

/* ================================
   SISTEMA DE COMBATE - SHOWCASE
   ================================ */

/* ================================
   PLANIFICACIÓN SIMULTÁNEA - 3 COLUMNAS
   ================================ */

.planning-three-columns {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 1rem;
    margin: 0rem 0;
    flex-wrap: wrap;
}

.planning-column {
    flex: 1;
    min-width: 200px;
    max-width: 250px;
}
.planning-column h4{
    margin-top:0px;
}

.column-title {
    text-align: center;
    font-size: 1rem;
    font-weight: 700;
    padding: 0.5rem;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    margin-bottom: 0;
}

.player-title {
    background: var(--accent-bio);
    color: var(--bg-primary);
}

.enemy-title {
    background: #ef4444;
    color: var(--bg-primary);
}

.execution-title {
    background: var(--accent-crystal);
    color: var(--bg-primary);
}

/* Actions List */
.actions-list,
.execution-list {
    background: var(--bg-tertiary);
    border: 2px solid var(--border);
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    padding: 0.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.action-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1.75rem 0.75rem;
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
}

.player-action {
    border-left: 3px solid var(--accent-bio);
}

.enemy-action {
    border-left: 3px solid #ef4444;
}

.action-icon {
    font-size: 1.5rem;
}

.action-name {
    flex: 1;
    /*font-weight: 600;*/
    color: var(--text-primary);
}

.action-cost {
    color: var(--accent-tech);
    font-weight: 700;
    font-size: var(--fs-small);
}

/* Operators */
.operator-column {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 0.5rem;
    margin-top: 2rem;
}

.operator {
    font-size: 2rem;
    font-weight: 700;
    color: var(--accent-crystal);
}

/* Execution List */
.execution-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem;
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    font-size: var(--fs-small);
}

.player-exec {
    border-left: 3px solid var(--accent-bio);
    background: rgba(74, 222, 128, 0.05);
}

.enemy-exec {
    border-left: 3px solid #ef4444;
    background: rgba(239, 68, 68, 0.05);
}

.exec-order {
    width: 20px;
    height: 20px;
    background: var(--accent-crystal);
    color: var(--bg-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
}

.exec-icon {
    font-size: 1rem;
}

.exec-text {
    flex: 1;
    /*font-weight: 600;*/
}

.exec-agi {
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-weight: 600;
}

.planning-note {
    margin-top: 1.5rem;
    padding: 1rem;
    background: var(--bg-tertiary);
    border-left: 3px solid var(--accent-crystal);
    border-radius: var(--radius-sm);
}

/* Responsive */
@media (max-width: 968px) {
    .planning-three-columns {
        flex-direction: column;
        align-items: center;
    }
    
    .operator-column {
        transform: rotate(90deg);
        margin: 0;
    }
    
    .planning-column {
        max-width: 100%;
        width: 100%;
    }
}


/* Agilidad Timeline */
.agility-timeline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0% 0;
    padding: 1.5rem;
    background: var(--bg-tertiary);
    border-radius: var(--radius-md);
}

.timeline-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.5rem;
}

.timeline-item.fast {
    color: var(--accent-bio);
}

.timeline-item.slow {
    color: var(--accent-chem);
}

.agi-value {
    font-weight: 700;
    font-size: 0.9rem;
}

.unit-icon {
    font-size: 2rem;
}

.unit-name {
    font-weight: 600;
}

.unit-desc {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.timeline-arrow {
    font-size: 1.5rem;
    color: var(--accent-crystal);
}

.showcase-card-body .showcase-note p{
    margin-bottom: 0;
}

.agility-note {
    margin-top: 1rem;
    padding: 1rem;
    background: var(--bg-tertiary);
    border-left: 3px solid var(--accent-crystal);
    border-radius: var(--radius-sm);
}

/* Combos Grid */
.combo-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

/* Para que se vea bien en móviles */
@media (max-width: 768px) {
    .combo-grid {
        grid-template-columns: 1fr;
    }
}

.combo-equation {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem;
    background: var(--bg-tertiary);
    border-radius: var(--radius-sm);
}

.combo-element {
    font-size: var(--fs-small);
    padding: 0.5rem 0.5rem;
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
}

.combo-plus,
.combo-equals {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--accent-crystal);
}

.combo-result {
    font-size: var(--fs-small);
    padding: 0.5rem 0.5rem;
    background: var(--accent-crystal);
    color: var(--bg-primary);
    border-radius: var(--radius-sm);
    
}

.combo-note {
    margin-top: 1.5rem;
    padding: 1rem;
    background: var(--bg-tertiary);
    border-left: 3px solid var(--accent-crystal);
    border-radius: var(--radius-sm);
}
/* ================================
   CAMPO DE BATALLA EVOLUCIONA
   ================================ */

.battlefield-evolution-horizontal {
    display: flex;
    gap: 2rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.battlefield-comparison {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex: 2;
    min-width: 300px;
}

.battlefield-state {
    text-align: center;
}

.battlefield-state h4 {
    color: var(--accent-crystal);
    margin-bottom: 1rem;
    font-size: 1.1rem;
}

.battle-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: repeat(5, 1fr);
    gap: 2px;
    background: var(--bg-tertiary);
    padding: 0.5rem;
    border-radius: var(--radius-md);
    border: 2px solid var(--border);
    width: 200px;
     position: relative; /* Agregar esto */
    overflow: hidden; /* Agregar esto */   
}

.battle-grid span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    background: var(--bg-secondary);
    border-radius: 2px;
}

.battle-grid.intact {
    border-color: var(--accent-bio);
    box-shadow: 0 0 20px rgba(74, 222, 128, 0.1);
}

.battle-grid.devastated {
    border-color: #ef4444;
    box-shadow: 0 0 20px rgba(239, 68, 68, 0.1);
}

.state-label {
    margin-top: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.evolution-arrow {
    font-size: 3rem;
    color: var(--accent-tech);
    align-self: center;
}

/* Effects section */
.battlefield-effects {
    flex: 1;
    min-width: 250px;
    background: var(--bg-tertiary);
    padding: 1.5rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
}

.battlefield-effects h4 {
    color: var(--accent-crystal);
    margin-bottom: 1rem;
    font-size: 0.9rem;
    text-align: center;
}

.effects-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.effect-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.25rem;
}

.effect-change {
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.effect-desc {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* Responsive */
@media (max-width: 968px) {
    .battlefield-evolution-horizontal {
        flex-direction: column;
        align-items: center;
    }
    
    .battlefield-comparison {
        flex-direction: column;
    }
    
    .evolution-arrow {
        transform: rotate(90deg);
    }
    
    .battlefield-effects {
        width: 100%;
    }
}

@media (max-width: 480px) {
    .battle-grid {
        width: 150px;
        height: 150px;
    }
    
    .battle-grid span {
        font-size: 1.2rem;
    }
    
    .effects-grid {
        grid-template-columns: 1fr;
    }
}
/* ================================
   FOG OF WAR - INFORMACIÓN IMPERFECTA
   ================================ */

.fog-vision-comparison {
    display: flex;
    justify-content: center;
    gap: 2rem;
    margin: 0rem 0;
    flex-wrap: wrap;
}

.vision-column {
    text-align: center;
    position:relative;
}

.vision-title {
    font-size: 1rem;
    font-weight: 700;
    padding: 0.5rem;
    margin-bottom: 0;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.player-vision {
    background: var(--accent-bio);
    color: var(--bg-primary);
}

.enemy-vision {
    background: #ef4444;
    color: var(--bg-primary);
}

.real-vision {
    background: var(--accent-crystal);
    color: var(--bg-primary);
}

.vision-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-template-rows: repeat(7, 1fr);
    gap: 1px;
    background: var(--bg-tertiary);
    padding: 0.5rem;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    /*width: 180px;
    height: 180px;*/
    border: 2px solid var(--border);
    border-top: none;
    position: relative; /* Agregar esto */
    overflow: hidden; /* Agregar esto */    
}

.vision-grid span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    background: var(--bg-secondary);
}

/* Grid específicos */
.player-grid {
    border-color: var(--accent-bio);
    box-shadow: 0 0 20px rgba(74, 222, 128, 0.1);
}

.enemy-grid {
    border-color: #ef4444;
    box-shadow: 0 0 20px rgba(239, 68, 68, 0.1);
}

.real-grid {
    border-color: var(--accent-crystal);
    box-shadow: 0 0 20px rgba(96, 165, 250, 0.1);
}

.vision-label {
    
    bottom: 0.5rem; /* Posicionar al fondo */
    left: 0;
    right: 0;
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.85rem;
    background: rgba(30, 41, 59, 0.9); /* Fondo semitransparente */
    padding: 0.25rem;
    margin: 0; /* Quitar margin */
}

/* Leyenda */
.vision-legend {
    margin-top: 1.5rem;
    padding: 1rem;
    background: var(--bg-tertiary);
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
}

.vision-legend h4 {
    color: var(--accent-crystal);
    font-size: 0.9rem;
    margin:0.5rem 0 1rem;
    text-align: center;
}

.legend-items {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.75rem;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.legend-icon {
    font-size: 1.2rem;
}

.legend-text {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

/* Nota final */
.fog-note {
    margin-top: 1.5rem;
    padding: 1rem;
    background: var(--bg-tertiary);
    border-left: 3px solid var(--accent-crystal);
    border-radius: var(--radius-sm);
}

/* Responsive */
@media (max-width: 768px) {
    .fog-vision-comparison {
        flex-direction: column;
        align-items: center;
    }
    
    .vision-grid {
        width: 150px;
        height: 150px;
    }
    
    .vision-grid span {
        font-size: 1rem;
    }
    
    .legend-items {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .legend-items {
        grid-template-columns: 1fr;
    }
}

/* ================================
   SCALE SHOWCASE WIDGET
   ================================ */
/* ========== SCALE SECTION SPECIFIC ========== */

/* Override tab color for conqueror theme */
.role-section-conqueror .tab-button.active::after {
    background: var(--accent-tech);
}

.role-section-conqueror .tab-button.active {
    color: var(--accent-tech);
}

/* Scale Level Grid Layout */
.scale-level-grid {
    display: grid;
    grid-template-columns: 1.25fr 2fr;
    gap: 2rem;
    align-items: start;
}

.scale-interface {
    background: var(--bg-tertiary);
    border: 2px solid var(--border);
    border-radius: var(--radius-md);
    padding: 0 1rem;
    text-align: center;
}

.scale-interface h3 {
    color: var(--accent-tech);
    font-size: 1.3rem;
    margin-bottom: 0.5rem;
}

.scale-interface p {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

/* Display elements */
.unit-display,
.planet-display,
.galaxy-display {
    font-size: 4rem;
    margin: 2rem 0;
}

.battle-grid-mini {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin: 2rem auto;
    font-size: 1.5rem;
}

.region-map {
    display: grid;
    grid-template-columns: repeat(3, 60px);
    gap: 0.5rem;
    justify-content: center;
    margin: 2rem 0;
}

.zone {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    font-weight: bold;
}

.zone.allied { 
    background: var(--accent-bio); 
    color: var(--bg-primary);
}
.zone.contested { 
    background: var(--accent-tech); 
    color: var(--bg-primary);
}
.zone.enemy { 
    background: #ef4444; 
    color: white;
}

.system-display {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    font-size: 3rem;
    margin: 2rem 0;
}

/* Description side */
.scale-description h3 {
    color: var(--accent-tech);
    font-size: 1.3rem;
    margin-bottom: 1rem;
}

.scale-description p {
    color: var(--text-secondary);
    line-height: 1.6;
    margin-bottom: 0.5rem;
}

.scale-description ul {
    list-style: none;
    padding: 0;
    margin-top:0px;
}

.scale-description li {
    color: var(--text-secondary);
    padding: 0 0 0.5rem;
    margin: 0;
}

/* Responsive */
@media (max-width: 768px) {
    .scale-level-grid {
        grid-template-columns: 1fr;
    }
    
    .tab-list {
        overflow-x: scroll;
    }
}
/* ================================
   ALLIANCE SYSTEM SECTION
   ================================ */

.alliance-section .subsection {
    margin: 3rem 0;
}

.alliance-section .subsection h3 {
    color: var(--accent-psi);
    font-size: 1.3rem;
    margin-bottom: 1.5rem;
}

/* ================================
   HIERARCHY TREE (Desktop) - 1.5.1
   ================================ */
.hierarchy-tree {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    padding: 2rem 0;
}
.hierarchy-pyramid {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin: var(--space-xl) 0;
}

.hierarchy-level {
    display: flex;
    justify-content: center;
    gap: var(--space-sm);
    flex-wrap: nowrap;
}


.hierarchy-level.level-supreme {
    margin-bottom: 1rem;
}

.hierarchy-level.level-supreme .role-card {
    border-color: var(--accent-psi);
    box-shadow: 0 0 20px rgba(167, 139, 250, 0.3);
    background: rgba(167, 139, 250, 0.05);
}

.hierarchy-level.level-officers .role-card {
    border-color: var(--accent-tech);
    background: rgba(245, 158, 11, 0.05);
}

.hierarchy-level.level-members .role-card {
    border-color: var(--border);
    background: var(--bg-secondary);
}

.hierarchy-connector {
    width: 4px;
    height: 40px;
    background: linear-gradient(to bottom,
        var(--accent-psi),
        rgba(167, 139, 250, 0.6),
        rgba(167, 139, 250, 0.3)
    );
    position: relative;
    border-radius: 2px;
    box-shadow: 0 0 10px rgba(167, 139, 250, 0.5);
    animation: glowPulse 2s ease-in-out infinite;
}

/* Arrow head (triangle) */
.hierarchy-connector::after {
    content: '';
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 12px solid var(--accent-psi);
    filter: drop-shadow(0 0 8px rgba(167, 139, 250, 0.6));
}

@keyframes glowPulse {
    0%, 100% {
        box-shadow: 0 0 10px rgba(167, 139, 250, 0.5);
    }
    50% {
        box-shadow: 0 0 20px rgba(167, 139, 250, 0.8);
    }
}

.hierarchy-card {
    max-width: 280px;
    min-width: 180px;
}

/* ================================
   HIERARCHY LIST (Mobile) - 1.5.1
   ================================ */
.hierarchy-list-mobile {
    display: none;
}

.hierarchy-arrow {
    text-align: center;
    font-size: 2rem;
    color: var(--accent-psi);
    margin: 0.5rem 0;
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 0.6; }
    50% { opacity: 1; }
}

/* Mobile responsive */
@media (max-width: 768px) {
    .hierarchy-tree {
        display: none;
    }

    .hierarchy-list-mobile {
        display: flex;
        flex-direction: column;
        gap: 0;
        padding: 1rem 0;
    }

    .mobile-card {
        width: 100%;
    }
}

/* ================================
   ROLE CARDS (General)
   ================================ */
.role-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

.role-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    text-align: center;
    transition: all var(--transition-fast);
}



.role-icon {
    font-size: 2.5rem;
    display: block;
    margin-bottom: 1rem;
}

.role-card h4 {
    color: var(--text-primary);
    margin-bottom: 0.5rem;
}

.role-card p {
    color: var(--text-secondary);
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

.role-req {
    font-size: 0.8rem;
    color: var(--accent-psi);
    font-style: italic;
}

/* ================================
   ENHANCED CARDS WITH BADGES - 1.5.2 & 1.5.3
   ================================ */
.card-badge {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    padding: 0.25rem 0.75rem;
    border-radius: 12px;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

/* 1.5.2 Internal badges */
.badge-structure {
    background: linear-gradient(135deg, #4338ca, #6366f1);
    color: white;
}

.badge-resource {
    background: linear-gradient(135deg, #f59e0b, #fbbf24);
    color: #1a1a1a;
}

.badge-power {
    background: linear-gradient(135deg, #a855f7, #c084fc);
    color: white;
}

.badge-politics {
    background: linear-gradient(135deg, #06b6d4, #22d3ee);
    color: #1a1a1a;
}

.badge-expansion {
    background: linear-gradient(135deg, #10b981, #34d399);
    color: #1a1a1a;
}

.badge-ritual {
    background: linear-gradient(135deg, #dc2626, #ef4444);
    color: white;
}

/* 1.5.3 External badges */
.badge-war {
    background: linear-gradient(135deg, #dc2626, #f87171);
    color: white;
    animation: warPulse 2s ease-in-out infinite;
}

.badge-diplomacy {
    background: linear-gradient(135deg, #0891b2, #06b6d4);
    color: white;
}

.badge-dominance {
    background: linear-gradient(135deg, #9333ea, #a855f7);
    color: white;
}

.badge-economy {
    background: linear-gradient(135deg, #f59e0b, #fbbf24);
    color: #1a1a1a;
}

@keyframes warPulse {
    0%, 100% { box-shadow: 0 0 5px rgba(220, 38, 38, 0.5); }
    50% { box-shadow: 0 0 15px rgba(220, 38, 38, 0.8); }
}

/* Card type specific enhancements */
.card-internal {
    position: relative;
    overflow: visible;
}

.card-internal:hover {
    border-color: var(--accent-tech);
}

.card-external {
    position: relative;
    overflow: visible;
}

.card-external:hover {
    border-color: #dc2626;
    box-shadow: 0 10px 30px rgba(220, 38, 38, 0.2);
}

/* Enhanced icon for badge cards */
.card-internal .role-icon,
.card-external .role-icon {
    font-size: 3rem;
    margin-bottom: 1.5rem;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3));
}

/* Alliance Features */
.alliance-features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1rem;
}

.feature-icon {
    font-size: 1.8rem;
    flex-shrink: 0;
}

.feature-text h4 {
  margin-bottom: 0.25rem;
  margin-top: 0px;
}

.feature-text p {
    color: var(--text-secondary);
    font-size: 0.9rem;
}

/* NPC Grid */
.npc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
}

.npc-card {
    background: var(--bg-tertiary);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    text-align: center;
}

.npc-icon {
    font-size: 3rem;
    display: block;
    margin-bottom: 1rem;
}

.npc-card h4 {
    color: var(--accent-psi);
    margin-bottom: 0.5rem;
}

/* ================================
   DOCTRINE WARS DISPLAY
   ================================ */

/* Doctrine styles moved to css/components/doctrine-selector.css */

/* Meta Commentary Styles */
.meta-commentary {
    font-style: italic;
    color: #9ca3af;
    margin-top: 1.5rem;
    display: block;
}

.scale-final-note {
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(156, 163, 175, 0.3);
}

.scale-final-note p {
    font-style: italic;
    color: #9ca3af;
    margin: 0;
}

.showcase-note {
    margin-top: 1.5rem;
    padding: 1rem;
    background: rgba(30, 41, 59, 0.5);
    border-left: 3px solid #fbbf24;
    border-radius: 4px;
}

.showcase-note p {
    font-style: italic;
    color: #e5e7eb;
    margin: 0;
}

.showcase-note em {
    color: var(--text-primary);
}

.highlight-text {
    font-style: italic;
    color: #fbbf24;
    margin-top: 1.5rem;
    display: block;
}

/* ================================
   QUIZ SECTION - 1.3 ¿Qué Tipo de Salvador Serás?
   ================================ */

/* Doctrine Quiz Section */
.doctrine-quiz-section {
    margin: 3rem 0;
    padding: 2rem;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    border: 2px solid var(--border);
}

.doctrine-quiz-section h3 {
    color: var(--accent-bio);
    text-align: center;
    margin-top: 0;
    margin-bottom: 1rem;
    font-size: 1.5rem;
}

.quiz-subtitle {
    text-align: center;
    color: var(--text-secondary);
    font-style: italic;
    margin-bottom: 2rem;
}

/* Responsive */
@media (max-width: 768px) {
    .doctrine-quiz-section {
        padding: 1.5rem;
    }
}