/* ========================================
   ESTILOS DA GALERIA E LAYOUT
   ======================================== */
body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background-color: #e5e7eb;
    color: #1f2937;
    margin: 0;
    padding: 40px 20px;
    text-align: center;
}

h1 { margin-bottom: 10px; color: #111827; }

.instrucao {
    color: #4b5563;
    margin-bottom: 40px;
    font-size: 0.95rem;
}

.grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 30px;
    max-width: 1400px;
    margin: 0 auto;
}

.card {
    background: #ffffff;
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.card h3 { margin: 20px 0 5px 0; font-size: 1.1rem; color: #374151; }
.card p { font-size: 0.85rem; color: #6b7280; margin: 0; line-height: 1.4; }

.svg-container {
    width: 100%;
    max-width: 220px;
    aspect-ratio: 1 / 1;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.05); 
}

svg {
    width: 100%;
    height: 100%;
    display: block;
}

/* ========================================
   SISTEMA DE TEMAS E CORES DO SVG
   ======================================== */
.tema-padrao {
    --cor-fundo: #18224f;       
    --cor-engrenagem: #82bcd6;  
    --cor-contorno: #213f56; 
    --cor-anel: #3f6d8f;        
    --cor-icones: #ffffff;      
}

.tema-claro {
    --cor-fundo: #f4f7f6;       
    --cor-engrenagem: #f4f7f6;  
    --cor-contorno: #162029; 
    --cor-anel: #3498db;        
    --cor-icones: #2c3e50;      
}

.tema-escuro {
    --cor-fundo: #111827;       
    --cor-engrenagem: #374151;  
    --cor-contorno: #0b101a; 
    --cor-anel: #60a5fa;        
    --cor-icones: #ffffff;      
}

.tema-verde {
    --cor-fundo: #082614;       
    --cor-engrenagem: #17a554;  
    --cor-contorno: #0a4a25; 
    --cor-anel: #86efac;        
    --cor-icones: #ffffff;      
}

.tema-verde-claro {
    --cor-fundo: #f4f9f6;       
    --cor-engrenagem: #17a554;  
    --cor-contorno: #0a4a25; 
    --cor-anel: #6ee7b7;        
    --cor-icones: #0a4a25;      
}

.tema-laranja {
    --cor-fundo: #2b1408;       
    --cor-engrenagem: #e67e22;  
    --cor-contorno: #6b380d; 
    --cor-anel: #f1c40f;        
    --cor-icones: #ffffff;      
}

.tema-laranja-claro {
    --cor-fundo: #fffaf5;       
    --cor-engrenagem: #e67e22;  
    --cor-contorno: #783c00; 
    --cor-anel: #f8c471;        
    --cor-icones: #783c00;      
}

.tema-monocromatico {
    --cor-fundo: #ffffff;       
    --cor-engrenagem: transparent;  
    --cor-contorno: #1a1a1a; 
    --cor-anel: #1a1a1a;        
    --cor-icones: #1a1a1a;      
}

.tema-bicromatico {
    --cor-fundo: #ffffff;       
    --cor-engrenagem: transparent;  
    --cor-contorno: #737373; 
    --cor-anel: #737373;        
    --cor-icones: #1a1a1a;      
}

.tema-escala-cinza {
    --cor-fundo: #f0f0f0;       
    --cor-engrenagem: #737373;  
    --cor-contorno: #404040; 
    --cor-anel: #a6a6a6;        
    --cor-icones: #1a1a1a;      
}

/* ========================================
   MAPEAMENTO DE CAMADAS E RENDERIZAÇÃO DO SVG
   ======================================== */
.fundo { fill: var(--cor-fundo); stroke: none; }
.anel { fill: var(--cor-anel); stroke: none; }
.icone { fill: var(--cor-icones); stroke: none; }

.fundo-icone { 
    fill: var(--cor-fundo); 
    stroke: var(--cor-fundo); 
    stroke-width: 1.5px; 
    stroke-linejoin: round; 
}

.retangulo-fundo { fill: var(--cor-fundo); }
.fundo-transparente .retangulo-fundo { display: none; }

.engrenagem-solida {
    fill: var(--cor-engrenagem);
    stroke: none;
}

.engrenagem-contorno-linha {
    fill: none;
    stroke: var(--cor-contorno);
    stroke-width: 14px; 
    stroke-linecap: round;
    stroke-linejoin: round;
}