:root {
  /* Default Green Theme */
  --accent-color: #2ECC71;
  --accent-hover: #27AE60;
  --accent-glow: rgba(46, 204, 113, 0.4);
  --accent-rgb: 46, 204, 113;
}

/* Base Styles */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'Poppins', sans-serif;
  font-variation-settings: 'wght' 400;
  -webkit-tap-highlight-color: transparent;
}

html, body {
  width: 100%;
  overflow-x: hidden;
}

body {
  background: #101010;
  color: #FFFFFF;
  overflow-y: auto;
}

/* Hide sidebar and main content when a mode is active */
body.mode-active .invix-sidebar,
body.mode-active .invix-main {
  display: none;
}

/* Sidebar Styles */
.invix-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: 60px; /* Largura compacta padrão */
  height: 100%;
  background: rgba(0, 10, 10, 0.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 15px;
  display: flex;
  flex-direction: column;
  box-shadow: 2px 0 8px rgba(0, 0, 0, 0.4);
  z-index: 200;
  transition: width 0.3s ease; /* Transição suave para a largura */
  overflow: hidden; /* Esconde o conteúdo que excede a largura */
}

/* Expande a sidebar ao passar o mouse */
.invix-sidebar:hover {
    width: 200px; /* Largura expandida ao passar o mouse */
}

.user-info {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
  color: var(--accent-color);
}



.user-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--accent-color);
  margin-right: 8px;
  background-color: rgba(var(--accent-rgb), 0.1);
}



.user-name {
  font-size: 1rem;
  font-variation-settings: 'wght' 500;
  display: none; /* Esconde o nome do usuário por padrão */
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* Mostra o nome do usuário ao passar o mouse */
.invix-sidebar:hover .user-name {
    display: inline;
    opacity: 1;
}

.invix-sidebar ul {
  list-style: none;
}

.invix-sidebar ul li {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 8px;
  margin: 5px 0;
  cursor: pointer;
  border-radius: 8px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.invix-sidebar:hover ul li {
  justify-content: flex-start;
}

.invix-sidebar ul li:hover, .invix-sidebar ul li.active {
  background: rgba(var(--accent-rgb), 0.3);
  transform: scale(1.03);
}

.invix-sidebar ul li .emoji-icon {
  font-size: 1.5rem;
  margin-right: 0;
  text-shadow: 0 0 5px var(--accent-glow);
  transition: margin-right 0.3s ease;
}

.invix-sidebar:hover ul li .emoji-icon {
  margin-right: 8px;
}






.invix-sidebar ul li .label {
  font-size: 0.9rem;
  font-variation-settings: 'wght' 500;
  display: none; /* Esconde o rótulo por padrão */
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* Mostra o rótulo ao passar o mouse */
.invix-sidebar:hover ul li .label {
    display: inline;
    opacity: 1;
}

/* Main Content Area */
.invix-main {
  margin-left: 60px; /* Margem inicial para a sidebar compacta */
  padding: 15px;
  min-height: 100vh;
  transition: margin-left 0.3s ease;
}

/* Ajusta a margem do conteúdo principal quando a sidebar está expandida via JS */
body.sidebar-expanded .invix-main {
    margin-left: 200px;
}

.invix-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px;
  animation: slideIn 0.5s ease-in-out;
}

@keyframes slideIn {
  from { opacity: 0; transform: translateX(-30px); }
  to { opacity: 1; transform: translateX(0); }
}

/* Welcome Banner */
.welcome-banner {
  background: rgba(30, 30, 30, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 20px;
  border-radius: 8px;
  border-image: linear-gradient(45deg, var(--accent-color), transparent) 1;
  animation: fadeIn 1s ease-in;
  margin-bottom: 20px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: center;
}

.welcome-content h1 {
  font-size: 1.75rem;
  font-variation-settings: 'wght' 600;
  color: var(--accent-color);
  margin-bottom: 10px;
}

.welcome-content p {
  font-size: 0.9rem;
  margin: 0;
}

.skills-xp h3 {
  font-size: 1.2rem;
  color: var(--accent-color);
  margin-bottom: 15px;
  text-align: center;
}

.skills-xp-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.skill-xp-item {
  background: rgba(255, 255, 255, 0.05);
  padding: 8px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.skill-xp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 5px;
}

.skill-xp-name {
  font-size: 0.75rem;
  font-weight: 500;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 4px;
}

.skill-xp-value {
  font-size: 0.7rem;
  color: var(--accent-color);
  font-weight: 600;
}

.skill-xp-bar {
  background: rgba(255, 255, 255, 0.1);
  height: 4px;
  border-radius: 2px;
  overflow: hidden;
}

.skill-xp-progress {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-color), var(--accent-hover));
  border-radius: 2px;
  transition: width 0.8s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-20px); }
  to { opacity: 1; transform: translateY(0); }
}



/* Dashboard Grid and Settings Container */
.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(140px, 25vw, 180px), 1fr));
  gap: clamp(15px, 3vw, 20px);
  margin-bottom: 20px;
  justify-items: center;
}

.settings-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}

/* Settings Card Styles */
.settings-card {
  background: rgba(30, 30, 30, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 20px;
  border-radius: 10px;
  border-image: linear-gradient(45deg, var(--accent-color), transparent) 1;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  transition: all 0.3s ease;
}

.settings-card-full-width {
    grid-column: 1 / -1;
    max-width: none;
}

.settings-card h3 {
  font-size: 1.2rem;
  color: var(--accent-color);
  margin-bottom: 15px;
  font-variation-settings: 'wght' 600;
}

.settings-option {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin: 10px 0;
}

.settings-option label {
  width: 100%;
  font-size: 0.9rem;
  color: #FFFFFF;
  margin-bottom: 8px;
}

.settings-option input[type="text"],
.settings-option input[type="number"],
.settings-option select,
.settings-option textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.05);
  color: #FFFFFF;
  font-size: 0.9rem;
  transition: border-color 0.3s ease;
}

.settings-option input[type="text"]:focus,
.settings-option input[type="number"]:focus,
.settings-option select:focus,
.settings-option textarea:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 5px var(--accent-glow);
}

.settings-option select option {
  background: #101010;
  color: #FFFFFF;
}

.settings-option input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-top: 5px;
}

.settings-option input[type="range"] {
  width: 100%;
  margin-top: 5px;
}

/* Tile Styles */
.tile {
  background: rgba(30, 30, 30, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 15px;
  border-radius: 8px;
  border-image: linear-gradient(45deg, var(--accent-color), transparent) 1;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  justify-content: center;
  transform: perspective(1000px) rotateY(0deg);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), transparent);
  animation: fadeIn 0.5s ease;
  min-height: 120px;
}

.tile:hover {
  transform: perspective(1000px) rotateY(3deg) translateY(-5px);
  box-shadow: 0 6px 18px var(--accent-glow);
}

.tile h2 {
  color: var(--accent-color);
  font-size: 1.25rem;
  margin-bottom: 10px;
}

.tile p {
  font-size: 0.9rem;
}

.mode-card {
  cursor: pointer;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: clamp(120px, 20vh, 150px);
  padding: clamp(10px, 2.5vw, 15px);
  width: 100%;
  max-width: clamp(140px, 30vw, 200px);
}

.mode-card .emoji-icon {
  font-size: clamp(2.2rem, 5vw, 3rem);
  margin-bottom: clamp(5px, 1.5vh, 10px);
}

/* Call to Action Buttons */
.cta-button {
  padding: 12px 24px;
  border: none;
  border-radius: 8px;
  background: var(--accent-color);
  color: #FFFFFF;
  font-variation-settings: 'wght' 600;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.3s ease;
  width: auto;
  margin-top: 15px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.cta-button:hover {
  background: var(--accent-hover);
  box-shadow: 0 0 12px var(--accent-glow);
  transform: translateY(-2px);
}

#mode-container {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100;
  pointer-events: none;
  overflow: hidden;
  background: transparent;
  overscroll-behavior: none;
  touch-action: pan-y;
}

#mode-container.active-mode {
  display: block;
  pointer-events: auto;
}

#mode-container.active-mode #canvas {
    z-index: 1;
}
#mode-container.active-mode.iwant-mode-gradient-bg #canvas {
    display: none;
}

#canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 1;
  touch-action: none;
  overscroll-behavior: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
}

/* ESTILOS PARA RELATÓRIOS */
.report-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
    background: rgba(30, 30, 30, 0.8);
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
}

.report-controls .settings-option {
    margin: 0;
}

.report-controls .cta-button {
    margin-top: 0;
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 25px;
}

.summary-grid .tile h4 {
    font-size: 1rem;
    color: var(--accent-color);
    margin-bottom: 10px;
    font-variation-settings: 'wght' 500;
}

.summary-grid .tile p {
    font-size: 1.5rem;
    font-variation-settings: 'wght' 600;
}

.report-card {
    background: rgba(30, 30, 30, 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 20px;
    border-radius: 10px;
    margin-bottom: 20px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.report-card h3 {
    color: var(--accent-color);
    margin-bottom: 10px;
}

.report-description {
    font-size: 0.9rem;
    color: #cccccc;
    margin-bottom: 20px;
    line-height: 1.6;
}

.report-insight {
    font-size: 0.9rem;
    color: #dddddd;
    background: rgba(var(--accent-rgb), 0.1);
    border-left: 3px solid var(--accent-color);
    padding: 12px;
    margin-top: 20px;
    border-radius: 4px;
    line-height: 1.6;
}

.chart-container {
    position: relative;
    height: 350px;
    width: 100%;
    overflow: hidden;
}

#focus-pattern-card {
    overflow: visible;
}

#focus-pattern-card .chart-container {
    height: 300px;
    margin: 10px 0;
}

#focus-pattern-chart {
    max-width: 100%;
    height: auto;
}

/* Activity-specific elements */
.shape, .learning-item, .breath-circle, .breath-text, .form-shape, .tactile-pattern, .number-item, .mascot, .portal-shape {
  position: absolute;
  pointer-events: auto;
  z-index: 102;
}

.learning-item, .number-item {
  line-height: 1.2;
  text-align: center;
  text-shadow: 0 0 8px rgba(255,255,200, 0.8);
}

.learning-item .emoji-icon, .number-item .emoji-icon {
  font-size: 1em;
}

.learning-item .letter, .number-item .number {
  font-size: 0.5em;
  font-weight: 600;
}

/* Back and Pause Buttons in Mode */
#back-button {
  position: fixed;
  top: clamp(15px, 3vh, 25px);
  right: clamp(15px, 3vw, 25px);
  padding: clamp(8px, 2vw, 12px) clamp(15px, 3vw, 20px);
  font-size: clamp(0.8rem, 2.5vw, 1rem);
  z-index: 103;
  border-radius: clamp(6px, 1.5vw, 8px);
  background: #27AE60;
  color: white;
  border: none;
}

/* Temas */
.theme-green { --accent-color: #2ECC71; --accent-hover: #27AE60; --accent-glow: rgba(46, 204, 113, 0.4); --accent-rgb: 46, 204, 113; }
.theme-blue { --accent-color: #3498DB; --accent-hover: #2980B9; --accent-glow: rgba(52, 152, 219, 0.4); --accent-rgb: 52, 152, 219; }
.theme-purple { --accent-color: #9B59B6; --accent-hover: #8E44AD; --accent-glow: rgba(155, 89, 182, 0.4); --accent-rgb: 155, 89, 182; }
.theme-yellow { --accent-color: #F1C40F; --accent-hover: #F39C12; --accent-glow: rgba(241, 196, 15, 0.4); --accent-rgb: 241, 196, 15; }
.theme-cyan { --accent-color: #1ABC9C; --accent-hover: #16A085; --accent-glow: rgba(26, 188, 156, 0.4); --accent-rgb: 26, 188, 156; }
.theme-orange { --accent-color: #E67E22; --accent-hover: #D35400; --accent-glow: rgba(230, 126, 34, 0.4); --accent-rgb: 230, 126, 34; }
.theme-pink { --accent-color: #FFC0CB; --accent-hover: #FFB6C1; --accent-glow: rgba(255, 192, 203, 0.4); --accent-rgb: 255, 192, 203; }
.theme-magenta { --accent-color: #FF00FF; --accent-hover: #EE00EE; --accent-glow: rgba(255, 0, 255, 0.4); --accent-rgb: 255, 0, 255; }
.theme-white { --accent-color: #FFFFFF; --accent-hover: #E0E0E0; --accent-glow: rgba(255, 255, 255, 0.4); --accent-rgb: 255, 255, 255; }
.theme-teal { --accent-color: #008080; --accent-hover: #006666; --accent-glow: rgba(0, 128, 128, 0.4); --accent-rgb: 0, 128, 128; }

/* High Contrast */
.high-contrast {
  background: #000000;
  color: #FFFF00;
}
.high-contrast .invix-sidebar, .high-contrast .tile, .high-contrast .welcome-banner, .high-contrast .settings-option, .high-contrast .report-card {
  background: #000000;
  color: #FFFF00;
  border: 2px solid #FFFF00;
  backdrop-filter: none;
}
.high-contrast .cta-button, .high-contrast .settings-option button {
  background: #FFFF00;
  color: #000000;
  border: 2px solid #FFFF00;
}

/* ESTILOS PARA MODO "EU QUERO" */
#mode-container.iwant-mode-gradient-bg {
  display: flex;
  justify-content: center;
  align-items: center;
}

.iwant-mode-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px;
  padding: 20px;
  overflow-y: auto;
  z-index: 101;
  place-items: center;
  max-width: 700px;
  margin: auto;
}

.iwant-button {
  width: 100%;
  aspect-ratio: 1 / 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: 15px;
  cursor: pointer;
  background: rgba(30, 30, 30, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.iwant-button:hover {
  transform: translateY(-5px) scale(1.02);
  box-shadow: 0 8px 20px var(--accent-glow);
  filter: brightness(1.1);
}

.iwant-button .emoji-icon {
  font-size: 5rem;
  margin-bottom: 5px;
  line-height: 1;
}

.iwant-button .button-text {
  font-size: 1.2rem;
  font-weight: 600;
  text-align: center;
  line-height: 1.2;
  padding: 0 5px;
}

.iwant-display-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 4rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 0 15px rgba(255, 255, 255, 0.7);
  background: rgba(0, 0, 0, 0.7);
  padding: 20px 30px;
  border-radius: 15px;
  z-index: 104;
  opacity: 0;
  animation: fadeAndPop 2s ease-out forwards;
  pointer-events: none;
  text-align: center;
  max-width: 90%;
  box-sizing: border-box;
}

@keyframes movingGradient {
  0% { background-position: 0% 0%; }
  25% { background-position: 100% 0%; }
  50% { background-position: 100% 100%; }
  75% { background-position: 0% 100%; }
  100% { background-position: 0% 0%; }
}

.iwant-mode-gradient-bg {
  background: linear-gradient(45deg, #2c3e50, #3498db, #2ecc71, #f1c40f);
  background-size: 400% 400%;
  animation: movingGradient 30s ease infinite;
}

.iwant-button.red { background-color: #e74c3c; }
.iwant-button.blue { background-color: #3498db; }
.iwant-button.green { background-color: #2ecc71; }
.iwant-button.yellow { background-color: #f1c40f; }
.iwant-button.orange { background-color: #e67e22; }
.iwant-button.purple { background-color: #9b59b6; }
.iwant-button.pink { background-color: #FF69B4; }
.iwant-button.teal { background-color: #008080; }
.iwant-button.brown { background-color: #8B4513; }
.iwant-button.gray { background-color: #7f8c8d; }

@keyframes fadeAndPop {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.8); }
  10% { opacity: 1; transform: translate(-50%, -50%) scale(1.05); }
  90% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(0.8); }
}

/* ESTILOS PARA MODO "MOVIMENTA, NOAH!" */
#movement-mode-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: linear-gradient(135deg, #FF6F61, #FED766);
    overflow: hidden;
    padding: 20px;
}

#movement-command {
    text-align: center;
    margin-bottom: 30px;
    z-index: 10;
}

#movement-emoji {
    font-size: 8rem;
    display: block;
    margin-bottom: 10px;
    animation: bounceIn 1s ease-out;
}

#movement-text {
    font-size: 3rem;
    font-weight: 700;
    color: #fff;
    text-shadow: 2px 2px 5px rgba(0,0,0,0.5);
    animation: fadeInScale 1.2s ease-out;
}

#movement-mascot {
    font-size: 10rem;
    position: absolute;
    bottom: 5%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 5;
    animation: mascotDance 2s infinite ease-in-out;
}

#next-movement-button, #next-movement {
    position: absolute;
    bottom: 20px;
    padding: 15px 30px;
    font-size: 1.5rem;
    z-index: 10;
    background-color: #4CAF50;
    color: white;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
    transition: all 0.3s ease;
}

#next-movement-button:hover, #next-movement:hover {
    background-color: #45a049;
    transform: scale(1.05);
}

@keyframes mascotDance {
    0%, 100% { transform: translateX(-50%) translateY(0px); }
    50% { transform: translateX(-50%) translateY(-20px); }
}

@keyframes mascotArmsUp {
    0%, 100% { transform: translateX(-50%) scaleY(1); }
    50% { transform: translateX(-50%) scaleY(1.1); }
}

@keyframes mascotJump {
    0%, 100% { transform: translateX(-50%) translateY(0px); }
    25%, 75% { transform: translateX(-50%) translateY(-50px); }
}

@keyframes mascotClap {
    0%, 100% { transform: translateX(-50%) scaleX(1); }
    25% { transform: translateX(-50%) scaleX(1.1); }
    50% { transform: translateX(-50%) scaleX(0.9); }
    75% { transform: translateX(-50%) scaleX(1.1); }
}

@keyframes bounceIn {
    0% { transform: scale(0.3); opacity: 0; }
    50% { transform: scale(1.1); opacity: 1; }
    70% { transform: scale(0.9); }
    100% { transform: scale(1); opacity: 1; }
}

@keyframes fadeInScale {
    0% { opacity: 0; transform: scale(0.8); }
    100% { opacity: 1; transform: scale(1); }
}

#movement-congratulations, #congratulations {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0, 0, 0, 0.8);
    padding: 40px;
    border-radius: 20px;
    text-align: center;
    font-size: 2rem;
    color: #FFD700;
    text-shadow: 0 0 10px rgba(255, 215, 0, 0.7);
    z-index: 20;
    animation: popOut 0.8s ease-out;
}

@keyframes popOut {
    0% { transform: translate(-50%, -50%) scale(0.5); opacity: 0; }
    80% { transform: translate(-50%, -50%) scale(1.1); opacity: 1; }
    100% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
}

/* Animations */
@keyframes pop {
  0% { transform: scale(0); opacity: 0; }
  50% { transform: scale(1.1); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}
@keyframes pulse {
  0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 0.8; }
  50% { transform: translate(-50%, -50%) scale(1.05); opacity: 1; }
}
@keyframes bounce {
  0%, 100% { transform: translate(-50%, -50%) translateY(0); }
  50% { transform: translate(-50%, -50%) translateY(-15px); }
}
@keyframes spin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to { transform: translate(-50%, -50%) rotate(360deg); }
}
@keyframes wave {
  0% { opacity: 0.7; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(2.5); }
}
@keyframes fadeOut {
  to { opacity: 0; transform: scale(0.3); }
}
@keyframes ripple {
  0% { transform: scale(1); opacity: 1; }
  100% { transform: scale(3); opacity: 0; }
}

/* ESTILOS PARA JOGOS EM DESTAQUE */
.featured-games-section {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 25px;
}

.featured-size {
    min-height: 160px;
    max-width: none;
}

.categories-section {
    margin-bottom: 20px;
}

.categories-section h3 {
    color: var(--accent-color);
    font-size: 1.1rem;
    margin: 15px 0 10px 0;
    font-weight: 500;
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: clamp(15px, 3vw, 20px);
    margin-bottom: 15px;
}

.featured-title {
    color: var(--accent-color);
    font-size: 1.4rem;
    margin: 30px 0 20px 0;
    text-align: center;
    font-weight: 600;
}

/* ESTILOS PARA SELEÇÃO DE AVATAR */
.avatar-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
    margin-top: 15px;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
}

.avatar-option {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s ease;
    background: rgba(255, 255, 255, 0.1);
    object-fit: cover;
    overflow: hidden;
    justify-self: center;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.avatar-option:hover {
    transform: scale(1.1);
    border-color: var(--accent-color);
}

.avatar-option.selected {
    border-color: var(--accent-color);
    box-shadow: 0 0 8px var(--accent-glow);
    background: rgba(var(--accent-rgb), 0.2);
}

/* Estilos específicos para o modo profissional */
.professional-mode .avatar-grid {
    display: grid !important;
    visibility: visible !important;
}

.professional-mode .avatar-option {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Professional Mode Tile Styles */
.professional-mode-tile {
    background: linear-gradient(135deg, rgba(46, 204, 113, 0.1), rgba(52, 152, 219, 0.1));
    border: 2px solid var(--accent-color);
    text-align: center;
    margin-bottom: 20px;
}

.professional-mode-tile h2 {
    color: var(--accent-color);
    font-size: 1.3rem;
    margin-bottom: 15px;
}

.professional-button {
    background: linear-gradient(135deg, var(--accent-color), var(--accent-hover));
    font-size: 1.1rem;
    padding: 15px 30px;
    margin-top: 20px;
    box-shadow: 0 4px 15px var(--accent-glow);
    text-decoration: none;
    display: inline-block;
}

.professional-button:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px var(--accent-glow);
    text-decoration: none;
    color: #FFFFFF;
}

/* RESPONSIVIDADE (MEDIA QUERIES) */

@media (max-width: 1200px) {
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 15px;
  }
  .featured-games-section {
    grid-template-columns: repeat(2, 1fr);
  }
  .category-grid {
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  }
}

@media (max-width: 1024px) {
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  }
  .settings-container {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  }
  .featured-games-section {
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }
  .category-grid {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  }
  .welcome-banner {
    grid-template-columns: 1fr;
    gap: 15px;
    padding: 15px;
  }
}

@media (max-width: 768px) {
  .invix-sidebar {
    width: 60px !important;
    cursor: pointer;
    z-index: 300;
  }
  .invix-sidebar.expanded {
    width: 200px !important;
    box-shadow: 4px 0 12px rgba(0, 0, 0, 0.6);
  }
  .invix-sidebar .user-name,
  .invix-sidebar ul li .label {
    display: none !important;
    opacity: 0 !important;
  }
  .invix-sidebar.expanded .user-name,
  .invix-sidebar.expanded ul li .label {
    display: inline !important;
    opacity: 1 !important;
  }
  .invix-sidebar ul li .emoji-icon {
    margin-right: 0 !important;
    width: auto !important;
  }
  .invix-sidebar.expanded ul li .emoji-icon {
    margin-right: 8px !important;
  }
  .invix-sidebar ul li {
    justify-content: center !important;
  }
  .invix-sidebar.expanded ul li {
    justify-content: flex-start !important;
  }
  .invix-main {
    margin-left: 60px !important;
    padding: 10px;
    transition: margin-left 0.3s ease;
  }
  .invix-main.sidebar-expanded {
    margin-left: 200px !important;
  }
  
  /* Grid responsivo */
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: 10px;
  }
  .settings-container {
    grid-template-columns: 1fr;
    gap: 15px;
  }
  .category-grid {
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 10px;
  }
  .featured-games-section {
    grid-template-columns: 1fr;
    gap: 15px;
  }
  .featured-size {
    min-height: 140px;
    max-width: none;
  }
  
  /* Botões e controles */
  #back-button, #pause-button, #clear-drawing-button, #clear-button {
    font-size: 0.8rem;
    padding: 8px 15px;
    border-radius: 6px;
    top: 15px;
    right: 15px;
  }
  
  /* Relatórios */
  .summary-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .chart-container {
    height: 250px;
    overflow: hidden;
  }
  .report-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  
  /* Modo "Eu Quero" */
  .iwant-mode-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    padding: 15px;
    max-width: 90%;
  }
  .iwant-button {
    min-width: 100px;
    min-height: 100px;
    padding: 10px;
  }
  .iwant-button .emoji-icon {
    font-size: 3rem;
  }
  .iwant-button .button-text {
    font-size: 0.9rem;
  }
  .iwant-display-text {
    font-size: 2.5rem;
    padding: 15px 20px;
    max-width: 85%;
  }
  
  /* Cards de modo */
  .mode-card {
    min-height: 110px;
    padding: 8px;
  }
  .mode-card .emoji-icon {
    font-size: 2.2rem;
  }
  .mode-card p {
    font-size: 0.8rem;
    line-height: 1.2;
  }
  
  /* Gamificação */
  .welcome-banner {
    grid-template-columns: 1fr;
    gap: 15px;
    padding: 15px;
  }
  .skills-xp-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  
  /* Movimento */
  #movement-emoji { font-size: 5rem; }
  #movement-text { font-size: 1.8rem; }
  #movement-mascot { font-size: 7rem; }
  #next-movement-button, #next-movement {
    font-size: 1.1rem;
    padding: 12px 20px;
  }
  #movement-congratulations, #congratulations {
    font-size: 1.4rem;
    padding: 25px;
  }
}

@media (max-width: 480px) {
  /* Sidebar mobile */
  .invix-sidebar {
    width: 50px;
    padding: 8px;
    z-index: 400;
  }
  .invix-sidebar.expanded {
    width: 180px;
  }
  .invix-sidebar .user-info {
    margin-bottom: 10px;
  }
  .invix-sidebar .user-icon {
    width: 35px;
    height: 35px;
  }
  .invix-sidebar ul li {
    padding: 8px 6px;
    margin: 3px 0;
  }
  .invix-sidebar ul li .emoji-icon {
    font-size: 1.3rem;
  }
  
  /* Main content */
  .invix-main {
    margin-left: 50px;
    padding: 8px;
    overflow-x: hidden;
  }
  .invix-main.sidebar-expanded {
    margin-left: 180px;
  }
  
  /* Welcome banner */
  .welcome-banner {
    padding: 12px;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .welcome-banner h1 {
    font-size: 1.3rem;
  }
  .welcome-content p {
    font-size: 0.85rem;
  }
  
  /* Grids */
  .dashboard-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .category-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .featured-games-section {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .featured-size {
    min-height: 110px;
  }
  
  /* Mode cards */
  .mode-card {
    min-height: 90px;
    padding: 6px;
  }
  .mode-card .emoji-icon {
    font-size: 1.8rem;
  }
  .mode-card p {
    font-size: 0.7rem;
    line-height: 1.1;
  }
  
  /* Botões */
  #back-button, #pause-button, #clear-drawing-button, #clear-button {
    top: 8px;
    right: 8px;
    padding: 6px 12px;
    font-size: 0.75rem;
  }
  .cta-button {
    padding: 10px 16px;
    font-size: 0.9rem;
  }
  
  /* Modo "Eu Quero" */
  .iwant-mode-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 10px;
    max-width: 95%;
  }
  .iwant-button {
    min-width: 80px;
    min-height: 80px;
    padding: 6px;
  }
  .iwant-button .emoji-icon {
    font-size: 2.2rem;
  }
  .iwant-button .button-text {
    font-size: 0.7rem;
  }
  .iwant-display-text {
    font-size: 1.6rem;
    padding: 12px 15px;
    max-width: 90%;
  }
  
  /* Gamificação */
  .skills-xp-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 5px;
  }
  .skill-xp-item {
    padding: 5px;
  }
  .skill-xp-name {
    font-size: 0.6rem;
  }
  .skill-xp-value {
    font-size: 0.55rem;
  }
  
  /* Movimento */
  #movement-emoji { font-size: 4rem; }
  #movement-text { font-size: 1.3rem; }
  #movement-mascot { font-size: 5rem; }
  #next-movement-button, #next-movement {
    font-size: 0.9rem;
    padding: 8px 16px;
  }
  #movement-congratulations, #congratulations {
    font-size: 1.1rem;
    padding: 15px;
  }
  
  /* Settings */
  .settings-card {
    padding: 15px;
  }
  .settings-option {
    margin: 8px 0;
  }
  .settings-option label {
    font-size: 0.85rem;
  }
  .settings-option input,
  .settings-option select {
    padding: 8px;
    font-size: 0.85rem;
  }
  
  /* Avatar grid */
  .avatar-grid {
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
  }
  .avatar-option {
    width: 35px;
    height: 35px;
  }
  
  /* Reports */
  .chart-container {
    height: 200px;
  }
  .report-controls {
    padding: 10px;
  }
  .report-controls .settings-option {
    margin: 5px 0;
  }
}

/* Orientação landscape em mobile */
@media (max-width: 768px) and (orientation: landscape) {
  .invix-main {
    padding: 5px;
  }
  .welcome-banner {
    padding: 10px;
  }
  .category-grid {
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  }
  .mode-card {
    min-height: 80px;
    padding: 5px;
  }
  .mode-card .emoji-icon {
    font-size: 1.5rem;
  }
  .mode-card p {
    font-size: 0.65rem;
  }
}

/* Telas muito pequenas */
@media (max-width: 320px) {
  .invix-sidebar {
    width: 45px;
  }
  .invix-sidebar.expanded {
    width: 160px;
  }
  .invix-main {
    margin-left: 45px;
  }
  .invix-main.sidebar-expanded {
    margin-left: 160px;
  }
  .dashboard-grid,
  .category-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }
  .mode-card {
    min-height: 80px;
    padding: 4px;
  }
  .mode-card .emoji-icon {
    font-size: 1.5rem;
  }
  .mode-card p {
    font-size: 0.65rem;
  }
  .welcome-banner h1 {
    font-size: 1.1rem;
  }
  .iwant-mode-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}
/* Aviso de orientação portrait - DESATIVADO */
.portrait-warning {
  display: none !important; /* Sempre escondido */
}

.landscape-only {
  display: block !important; /* Sempre visível */
}

/* Responsividade para orientação portrait */
@media (max-width: 768px) and (orientation: portrait) {
  .invix-main {
    padding: 10px 5px;
  }
  
  .welcome-banner {
    padding: 15px 10px;
  }
  
  .category-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .featured-games-section {
    grid-template-columns: 1fr;
  }
}
