/* ============================================
   ESTUDO PLANNER TEMPLATE — Base styles
   ============================================ */

:root {
  /* Paleta Foca+ — indigo premium + cream */
  --cor-principal: #4F46E5;
  --cor-escura: #3730A3;
  --cor-suave: #C7D2FE;
  --cor-bebe: #EEF2FF;
  --dourado: #B89968;
  --dourado-claro: #D4B98E;

  /* Neutros */
  --texto-principal: #1A1815;
  --texto-suave: #6B5F55;
  --bg-principal: #FAF7F2;
  --branco: #ffffff;

  --radius: 20px;
  --radius-sm: 16px;
  --radius-lg: 32px;
  --sombra-suave: 0 4px 18px rgba(212, 92, 133, 0.08);
  --sombra-media: 0 8px 30px rgba(200, 92, 133, 0.18);
  --sombra-forte: 0 12px 40px rgba(200, 92, 133, 0.28);

  /* Aliases para reaproveitar CSS do sofi-planner com cor dinâmica */
  --rosa-principal: var(--cor-principal);
  --rosa-vibrante: var(--cor-escura);
  --rosa-claro: var(--cor-suave);
  --rosa-medio: var(--cor-suave);
  --rosa-escuro: var(--cor-escura);
  --rosa-suave: var(--cor-bebe);
  --rosa-bebe: var(--cor-bebe);
  --rosa-pastel: var(--cor-suave);
  --off-white: #FFF8FB;
  --texto: var(--texto-principal);
  --texto-decorativo: var(--texto-suave);
  --verde-sucesso: #7BC47F;
  --cinza-claro: var(--cor-bebe);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html, body {
  margin: 0;
  padding: 0;
  font-family: 'Quicksand', sans-serif;
  background: var(--bg-principal);
  color: var(--texto-principal);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* ============================================
   SETUP WIZARD
   ============================================ */

.setup-wizard {
  min-height: 100vh;
  padding: 40px 24px 60px;
  max-width: 600px;
  margin: 0 auto;
  position: relative;
}

.setup-progress {
  height: 6px;
  background: rgba(0,0,0,0.06);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 12px;
}

.setup-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--cor-principal) 0%, var(--dourado) 100%);
  border-radius: 10px;
  transition: width 0.4s cubic-bezier(.4,0,.2,1);
}

.setup-contador {
  font-size: 12px;
  color: var(--texto-suave);
  text-align: right;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 28px;
}

.setup-container {
  position: relative;
}

.setup-etapa {
  display: none;
  animation: fadeIn 0.4s ease-out;
}

.setup-etapa.ativa {
  display: block;
}

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

.setup-emoji {
  font-size: 64px;
  text-align: center;
  margin-bottom: 16px;
}

.setup-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 38px;
  font-weight: 700;
  color: var(--cor-escura);
  text-align: center;
  margin: 0 0 10px 0;
  line-height: 1.2;
}

.setup-subtitulo {
  text-align: center;
  color: var(--texto-suave);
  font-size: 15px;
  margin: 0 0 36px 0;
  line-height: 1.5;
}

.setup-campo {
  margin-bottom: 24px;
}

.setup-campo label {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--texto-principal);
  margin-bottom: 10px;
  letter-spacing: 0.3px;
}

.campo-opcional {
  font-weight: 400;
  color: var(--texto-suave);
  font-size: 12px;
  font-style: italic;
}

.setup-campo input[type=text],
.setup-campo input[type=password] {
  width: 100%;
  padding: 14px 16px;
  border: 2px solid #F0E0E6;
  border-radius: 14px;
  font-family: 'Quicksand', sans-serif;
  font-size: 15px;
  color: var(--texto-principal);
  background: white;
  transition: border-color 0.2s;
}

.setup-campo input:focus {
  outline: none;
  border-color: var(--cor-principal);
}

.setup-explicacao {
  font-size: 12px;
  color: var(--texto-suave);
  margin-top: 8px;
  line-height: 1.5;
  font-style: italic;
}

/* Pills (opções múltiplas) */
.setup-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.pill {
  padding: 10px 16px;
  border: 2px solid #F0E0E6;
  border-radius: 20px;
  background: white;
  font-family: 'Quicksand', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--texto-principal);
  cursor: pointer;
  transition: all 0.2s;
}

.pill:hover {
  border-color: var(--cor-principal);
  transform: translateY(-1px);
}

.pill.selecionado {
  background: var(--cor-principal);
  border-color: var(--cor-principal);
  color: white;
  font-weight: 600;
}

/* Grade de áreas */
.setup-grid-areas {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 8px;
}

.area-card {
  padding: 14px 12px;
  border: 2px solid #F0E0E6;
  border-radius: 14px;
  background: white;
  cursor: pointer;
  text-align: center;
  transition: all 0.2s;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.area-card:hover {
  border-color: var(--cor-principal);
  transform: translateY(-2px);
}

.area-card.selecionado {
  background: var(--cor-suave);
  border-color: var(--cor-principal);
}

.area-card .emoji {
  font-size: 28px;
}

.area-card .nome {
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
}

/* Upload */
.setup-upload {
  background: white;
  border: 2px dashed #E8C5D2;
  border-radius: 16px;
  padding: 32px 20px;
  text-align: center;
  margin-bottom: 16px;
}

.botao-upload {
  background: white;
  border: 2px solid var(--cor-principal);
  border-radius: 24px;
  padding: 14px 24px;
  font-family: 'Quicksand', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--cor-principal);
  cursor: pointer;
  transition: all 0.2s;
}

.botao-upload:hover {
  background: var(--cor-principal);
  color: white;
}

.setup-upload-preview {
  margin-top: 16px;
}

.setup-upload-preview img {
  max-width: 100%;
  max-height: 240px;
  border-radius: 12px;
  box-shadow: var(--sombra-suave);
}

.setup-upload-preview .arquivo-nome {
  font-size: 13px;
  color: var(--texto-suave);
  margin-top: 8px;
}

.setup-processando {
  text-align: center;
  padding: 30px 20px;
  color: var(--texto-suave);
  font-size: 14px;
}

.setup-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid #F0E0E6;
  border-top-color: var(--cor-principal);
  border-radius: 50%;
  margin: 0 auto 12px;
  animation: spin 1s linear infinite;
}

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

.setup-grade-resultado {
  background: #F8FFF4;
  border: 2px solid #B8E0A8;
  border-radius: 14px;
  padding: 20px;
  margin-bottom: 16px;
}

.setup-grade-resultado h3 {
  margin: 0 0 12px 0;
  font-size: 16px;
  color: #4A7C59;
}

.setup-grade-resultado ul {
  margin: 0;
  padding-left: 20px;
  font-size: 13px;
  line-height: 1.6;
}

/* Tutorial collapsible */
.setup-tutorial {
  background: #FFF9E6;
  border: 1px solid var(--dourado-claro);
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 24px;
  font-size: 13px;
}

.setup-tutorial summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--texto-principal);
}

.setup-tutorial ol {
  margin: 12px 0 0 0;
  padding-left: 24px;
  line-height: 1.8;
}

.setup-tutorial a {
  color: var(--cor-principal);
  font-weight: 600;
}

/* Checkbox */
.checkbox-linha {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1.5;
  font-weight: 500 !important;
}

.checkbox-linha input[type=checkbox] {
  margin-top: 3px;
  width: 18px;
  height: 18px;
  accent-color: var(--cor-principal);
  cursor: pointer;
}

/* Ações (botões) */
.setup-acoes {
  display: flex;
  gap: 10px;
  margin-top: 32px;
  justify-content: flex-end;
}

.botao-setup {
  padding: 14px 28px;
  border: none;
  border-radius: 24px;
  background: var(--cor-principal);
  color: white;
  font-family: 'Quicksand', sans-serif;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
  box-shadow: var(--sombra-suave);
}

.botao-setup:hover {
  background: var(--cor-escura);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(212, 92, 133, 0.25);
}

.botao-setup:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.botao-voltar {
  background: white;
  color: var(--cor-principal);
  border: 2px solid var(--cor-principal);
  box-shadow: none;
}

.botao-voltar:hover {
  background: var(--cor-bebe);
  transform: none;
}

.botao-secundario {
  background: #E8E0E4;
  color: var(--texto-principal);
  box-shadow: none;
}

.botao-secundario:hover {
  background: #D5CCD1;
  transform: none;
}

.botao-final {
  background: linear-gradient(135deg, var(--cor-principal) 0%, var(--dourado) 100%);
  padding: 16px 36px;
  font-size: 16px;
}

/* Erro visual */
.campo-erro input {
  border-color: #E87474 !important;
}

.mensagem-erro {
  color: #C85C5C;
  font-size: 12px;
  margin-top: 6px;
  font-weight: 600;
}

/* Mobile adjustments */
@media (max-width: 500px) {
  .setup-titulo { font-size: 30px; }
  .setup-emoji { font-size: 52px; }
  .setup-acoes { flex-direction: column-reverse; }
  .setup-acoes button { width: 100%; }
}

/* iPad / Desktop */
@media (min-width: 768px) {
  .setup-wizard { padding: 60px 40px 80px; max-width: 700px; }
  .setup-titulo { font-size: 44px; }
}

/* ============================================
   APP PRINCIPAL — depois do setup
   ============================================ */

#app-principal {
  background: linear-gradient(180deg, var(--cor-bebe) 0%, var(--cor-suave) 50%, var(--bg-principal) 100%);
  min-height: 100vh;
  padding-bottom: 100px;
}

#app-principal h1, #app-principal h2, #app-principal h3, #app-principal .serif {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 600;
  color: var(--cor-escura);
}

.app {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ============ HEADER ============ */
.header {
  text-align: center;
  padding: 40px 20px 30px;
  background: linear-gradient(135deg, var(--cor-principal) 0%, var(--cor-escura) 100%);
  color: white;
  margin: 0 -20px 30px;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  box-shadow: var(--sombra-media);
  position: relative;
  overflow: hidden;
}

.header::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -30%;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%);
  border-radius: 50%;
}

.header::after {
  content: '';
  position: absolute;
  bottom: -40%;
  left: -20%;
  width: 250px;
  height: 250px;
  background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%);
  border-radius: 50%;
}

.header-conteudo { position: relative; z-index: 1; }

.header .saudacao {
  font-size: 14px;
  letter-spacing: 3px;
  text-transform: uppercase;
  opacity: 0.95;
  margin-bottom: 10px;
  font-weight: 600;
}

.header .nome {
  font-family: 'Dancing Script', cursive;
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 0.5px;
  line-height: 1.05;
  margin-bottom: 8px;
  color: white;
  text-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

.header .titulo {
  font-size: 14px;
  opacity: 1;
  letter-spacing: 1px;
  font-weight: 500;
}

.header-config-btn {
  position: absolute;
  top: 16px;
  right: 16px;
  background: rgba(255,255,255,0.2);
  border: 1px solid rgba(255,255,255,0.3);
  color: white;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  font-size: 18px;
  cursor: pointer;
  z-index: 2;
  transition: background 0.2s;
}
.header-config-btn:hover { background: rgba(255,255,255,0.35); }

/* ============ CARDS ============ */
.card {
  background: linear-gradient(180deg, #FFFFFF 0%, var(--cor-bebe) 100%);
  border: 1px solid var(--cor-bebe);
  border-radius: var(--radius);
  padding: 26px 22px;
  margin-bottom: 20px;
  box-shadow: var(--sombra-suave);
  transition: transform 0.2s, box-shadow 0.2s;
}

.card-titulo {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--cor-principal);
  margin-bottom: 14px;
  font-weight: 700;
}

.dica-card {
  font-size: 12px;
  color: var(--texto-suave);
  margin-top: 14px;
  text-align: center;
  font-style: italic;
}

.dica-paragrafo {
  font-size: 14px;
  color: var(--texto-suave);
  line-height: 1.5;
  margin-bottom: 16px;
}

/* ============ MENSAGEM DO DIA ============ */
.mensagem-do-dia {
  background: linear-gradient(135deg, var(--cor-suave) 0%, var(--cor-bebe) 100%);
  border: 2px solid var(--cor-suave);
  padding: 28px 24px 26px;
  border-radius: var(--radius);
  margin-bottom: 20px;
  position: relative;
  box-shadow: var(--sombra-suave);
}

.mensagem-do-dia .label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--cor-escura);
  margin-bottom: 12px;
  font-weight: 700;
}

.mensagem-do-dia .texto {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 22px;
  line-height: 1.45;
  color: var(--cor-escura);
  font-style: italic;
  font-weight: 600;
}

/* ============ VERSÍCULO / FRASE DO DIA ============ */
.versiculo {
  background: linear-gradient(135deg, #FFFBF0 0%, var(--cor-bebe) 100%);
  border: 2px solid var(--dourado-claro);
  border-radius: var(--radius);
  padding: 30px 24px;
  margin-bottom: 20px;
  text-align: center;
  box-shadow: 0 6px 24px rgba(201, 169, 97, 0.12);
}

.versiculo-ornamento {
  color: var(--dourado);
  font-size: 20px;
  letter-spacing: 6px;
  margin: 4px 0;
  opacity: 0.85;
}

.versiculo-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--dourado);
  font-weight: 700;
  margin: 8px 0 14px;
}

.versiculo-texto {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 21px;
  line-height: 1.5;
  color: var(--texto-principal);
  font-style: italic;
  font-weight: 600;
  margin-bottom: 14px;
  padding: 0 4px;
}

.versiculo-ref {
  font-family: 'Dancing Script', cursive;
  font-size: 20px;
  color: var(--cor-escura);
  font-weight: 700;
  margin-bottom: 6px;
  min-height: 22px;
}

.versiculo-original {
  font-size: 22px;
  line-height: 1.6;
  color: var(--cor-escura);
  font-weight: 600;
  margin-bottom: 6px;
  padding: 8px 12px;
  font-family: 'Amiri', 'Noto Serif', 'Cormorant Garamond', Georgia, serif;
  /* Fonts árabe/hebraico/devanágari fallback */
}

.versiculo-original.rtl {
  direction: rtl;
  font-family: 'Amiri', 'Noto Sans Hebrew', serif;
  font-size: 26px;
  line-height: 1.7;
}

.versiculo-original.devanagari {
  font-family: 'Noto Sans Devanagari', serif;
  font-size: 24px;
  line-height: 1.6;
}

.versiculo-original-lingua {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--dourado);
  font-weight: 700;
  margin-bottom: 14px;
  opacity: 0.85;
}

/* Separador discreto entre original e tradução */
.versiculo-original + .versiculo-original-lingua + .versiculo-texto::before {
  content: '';
  display: block;
  width: 50px;
  height: 1px;
  background: var(--cor-suave);
  margin: 12px auto 14px;
}

/* ============ STREAK ============ */
.streak-batalha {
  background: linear-gradient(135deg, var(--cor-principal) 0%, #FF6B6B 100%);
  color: white;
  border-radius: var(--radius);
  padding: 18px 22px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: var(--sombra-media);
  position: relative;
  overflow: hidden;
}

.streak-batalha::before {
  content: '';
  position: absolute;
  top: -40%;
  right: -20%;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, transparent 70%);
  border-radius: 50%;
}

.streak-icone {
  font-size: 38px;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
  position: relative;
  z-index: 1;
}

.streak-info { flex: 1; position: relative; z-index: 1; }

.streak-numero {
  font-size: 42px;
  font-weight: 700;
  line-height: 1;
  font-family: 'Quicksand', sans-serif;
}

.streak-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-top: 4px;
  font-weight: 600;
}

.streak-conquista {
  font-size: 12px;
  text-align: right;
  max-width: 140px;
  font-weight: 600;
  position: relative;
  z-index: 1;
  line-height: 1.3;
}

/* ============ COUNTDOWN ============ */
.countdown {
  background: linear-gradient(135deg, var(--cor-principal) 0%, var(--cor-escura) 100%);
  color: white;
  text-align: center;
  padding: 30px 22px;
  border-radius: var(--radius);
  margin-bottom: 20px;
  box-shadow: var(--sombra-media);
}

.countdown .label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 3px;
  opacity: 0.95;
  margin-bottom: 10px;
  font-weight: 600;
}

.countdown .prova-nome {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 26px;
  margin-bottom: 16px;
  font-weight: 700;
  color: white;
}

.countdown .dias {
  font-size: 78px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 6px;
  letter-spacing: -2px;
}

.countdown .unidade {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-weight: 600;
}

.countdown .data-prova {
  margin-top: 14px;
  font-size: 14px;
  opacity: 0.95;
}

/* ============ PRÓXIMAS PROVAS (mini cards) ============ */
.proximas-provas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 20px;
}

.prova-mini {
  background: linear-gradient(180deg, white 0%, var(--cor-bebe) 100%);
  border: 2px solid var(--cor-suave);
  border-radius: var(--radius);
  padding: 18px 14px;
  text-align: center;
  box-shadow: var(--sombra-suave);
}

.prova-mini-ordem {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--cor-escura);
  font-weight: 700;
  margin-bottom: 6px;
}
.prova-mini-icone { font-size: 26px; margin-bottom: 4px; }
.prova-mini-nome {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--cor-escura);
  line-height: 1.2;
  margin-bottom: 8px;
  min-height: 44px;
  display: flex; align-items: center; justify-content: center;
}
.prova-mini-data { font-size: 14px; font-weight: 700; color: var(--texto-principal); margin-bottom: 4px; }
.prova-mini-dias { font-size: 11px; color: var(--cor-principal); font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }

/* ============ EVENTOS / CALENDÁRIO ============ */
.lista-eventos { list-style: none; padding: 0; margin: 0; }

.evento {
  display: flex;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid var(--cor-suave);
  gap: 14px;
}
.evento:last-child { border-bottom: none; }

.evento-data {
  background: var(--cor-suave);
  color: var(--cor-escura);
  width: 52px; height: 52px;
  border-radius: 12px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  flex-shrink: 0;
  font-weight: 600;
}
.evento.prova .evento-data { background: var(--cor-principal); color: white; }
.evento.feriado .evento-data { background: #E8F5E9; color: var(--verde-sucesso); }
.evento.evento .evento-data { background: #F3E5F5; color: #9C27B0; }
.evento-data .dia { font-size: 20px; line-height: 1; }
.evento-data .mes { font-size: 10px; text-transform: uppercase; margin-top: 2px; letter-spacing: 1px; }
.evento-info { flex: 1; min-width: 0; }
.evento-titulo { font-size: 16px; font-weight: 600; color: var(--texto-principal); margin-bottom: 4px; line-height: 1.35; }
.evento.destaque .evento-titulo { font-weight: 700; color: var(--cor-escura); }
.evento-semana { font-size: 12px; color: var(--cor-principal); font-weight: 500; }
.evento-icone { font-size: 26px; opacity: 0.9; }

.evento-remover {
  background: transparent; border: none;
  color: var(--texto-suave); cursor: pointer;
  font-size: 22px; padding: 4px 8px;
  opacity: 0.5; line-height: 1;
}
.evento-remover:hover { opacity: 1; color: var(--cor-principal); }

/* ============ MATÉRIAS ============ */
.materias-lista { display: flex; flex-direction: column; gap: 10px; }

.materia-item {
  display: flex; align-items: center;
  padding: 12px 14px;
  background: var(--cor-bebe);
  border-radius: var(--radius-sm);
  gap: 12px;
}
.materia-item.concluida { background: #E8F5E9; opacity: 0.7; }
.materia-item.concluida .materia-nome { text-decoration: line-through; color: var(--texto-suave); }

.materia-check {
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 2.5px solid var(--cor-principal);
  background: white;
  cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.materia-item.concluida .materia-check { background: var(--verde-sucesso); border-color: var(--verde-sucesso); }
.materia-check::after { content: '✓'; color: white; font-weight: bold; font-size: 15px; opacity: 0; }
.materia-item.concluida .materia-check::after { opacity: 1; }
.materia-nome { flex: 1; font-size: 16px; font-weight: 500; color: var(--texto-principal); }
.materia-remover { background: transparent; border: none; color: var(--texto-suave); cursor: pointer; font-size: 18px; padding: 4px 8px; opacity: 0.5; }
.materia-remover:hover { opacity: 1; color: var(--cor-principal); }

.sugestoes-materias { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 6px; }
.sugestoes-materias .sugestao-titulo { width: 100%; font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--texto-suave); font-weight: 700; margin-bottom: 6px; }
.sugestoes-materias .sugestao-chip {
  background: white; border: 1px dashed var(--cor-suave);
  color: var(--cor-escura); padding: 6px 12px;
  border-radius: 999px; font-size: 12px; font-family: inherit;
  cursor: pointer; transition: all 0.15s; font-weight: 600;
}
.sugestoes-materias .sugestao-chip:hover { background: var(--cor-bebe); border-color: var(--cor-principal); }

/* ============ INPUT ============ */
.input-linha { display: flex; gap: 8px; margin-top: 14px; }

.input {
  flex: 1;
  padding: 14px 16px;
  border: 2px solid var(--cor-suave);
  border-radius: var(--radius-sm);
  font-size: 15px;
  font-family: inherit;
  background: white;
  outline: none;
  color: var(--texto-principal);
  font-weight: 500;
  width: 100%;
}
.input:focus { border-color: var(--cor-principal); }

/* ============ BOTÕES ============ */
.botao {
  background: linear-gradient(135deg, var(--cor-principal) 0%, var(--cor-escura) 100%);
  color: white; border: none;
  padding: 14px 24px;
  border-radius: var(--radius-sm);
  font-size: 15px; font-weight: 700;
  cursor: pointer; font-family: inherit;
  transition: all 0.2s;
  letter-spacing: 0.5px;
  box-shadow: var(--sombra-suave);
}
.botao:hover { transform: translateY(-1px); }
.botao:active { transform: translateY(0); }

.botao-secundario {
  background: var(--cor-suave);
  color: var(--cor-escura);
  box-shadow: none;
}
.botao-secundario:hover { background: var(--cor-bebe); }

.botao-perigo {
  background: #FFEBEE;
  color: #C62828;
  box-shadow: none;
}
.botao-perigo:hover { background: #FFCDD2; }

/* ============ PLANNER SEMANAL ============ */
.planner-semana {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-top: 14px;
}
.planner-dia {
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  background: var(--cor-bebe);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 6px; cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.15s;
  text-align: center;
}
.planner-dia.hoje { background: var(--cor-principal); color: white; }
.planner-dia.estudou { background: var(--verde-sucesso); color: white; }
.planner-dia.futuro { opacity: 0.5; }
.planner-dia-letra { font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px; opacity: 0.85; font-weight: 600; }
.planner-dia-numero { font-size: 18px; font-weight: 700; margin-top: 3px; }

/* ============ PROGRESSO ============ */
.progresso-wrapper { margin-top: 14px; }
.progresso-barra { height: 10px; background: var(--cor-suave); border-radius: 10px; overflow: hidden; margin-top: 8px; }
.progresso-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--cor-principal), var(--cor-escura));
  border-radius: 10px;
  transition: width 0.5s ease;
}
.progresso-texto {
  font-size: 14px; color: var(--texto-principal);
  display: flex; justify-content: space-between;
  margin-bottom: 6px; font-weight: 500;
}
.progresso-texto strong { color: var(--cor-escura); font-weight: 700; }

/* ============ POMODORO ============ */
.pomodoro-card { background: linear-gradient(135deg, var(--cor-bebe) 0%, white 100%); }
.pomodoro { text-align: center; padding: 20px 10px 10px; }
.pomodoro-status { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 18px; color: var(--cor-escura); font-weight: 600; margin-bottom: 10px; min-height: 24px; }
.pomodoro-timer {
  font-family: 'Quicksand', sans-serif;
  font-size: 86px; font-weight: 700;
  color: var(--cor-principal);
  line-height: 1; letter-spacing: -3px;
  margin: 16px 0;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 4px 16px rgba(0,0,0,0.10);
}
.pomodoro-ciclo { font-size: 12px; text-transform: uppercase; letter-spacing: 2px; color: var(--texto-suave); margin-bottom: 18px; font-weight: 500; }
.pomodoro-acoes { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.pomodoro-dica { font-size: 12px; color: var(--texto-suave); margin-top: 18px; font-style: italic; }
.pomodoro.ativo .pomodoro-timer { animation: pulsar 2s ease-in-out infinite; }
.pomodoro.descanso .pomodoro-timer { color: var(--verde-sucesso); }
@keyframes pulsar { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.02); } }

/* ============ UPLOAD / IA ============ */
.upload-area {
  border: 2.5px dashed var(--cor-suave);
  border-radius: var(--radius);
  padding: 38px 18px;
  text-align: center;
  background: var(--cor-bebe);
  cursor: pointer;
  transition: all 0.2s;
}
.upload-area:hover, .upload-area.drag {
  border-color: var(--cor-principal);
  background: var(--cor-suave);
  transform: translateY(-2px);
}
.upload-icone { font-size: 44px; margin-bottom: 10px; }
.upload-titulo { font-size: 16px; font-weight: 600; color: var(--cor-escura); margin-bottom: 6px; }
.upload-subtitulo { font-size: 12px; color: var(--texto-suave); }

.arquivo-chip {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  background: var(--cor-bebe);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
  font-size: 13px;
}
.arquivo-chip .arquivo-icone { font-size: 22px; }
.arquivo-chip .arquivo-nome { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.arquivo-chip .arquivo-remover { background: transparent; border: none; color: var(--texto-suave); cursor: pointer; font-size: 18px; padding: 4px 8px; }

.modo-botoes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 14px; }
.botao-modo {
  padding: 18px 12px;
  border: 2px solid var(--cor-suave);
  background: white;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-align: center;
  font-family: inherit;
  transition: all 0.2s;
}
.botao-modo:hover { border-color: var(--cor-principal); background: var(--cor-bebe); transform: translateY(-2px); }
.modo-icone { font-size: 30px; margin-bottom: 6px; }
.modo-titulo { font-size: 14px; font-weight: 600; color: var(--cor-escura); margin-bottom: 4px; }
.modo-sub { font-size: 11px; color: var(--texto-suave); line-height: 1.3; }

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

.resumo-ia {
  background: white;
  border: 2px solid var(--cor-suave);
  border-radius: var(--radius);
  padding: 20px;
  margin-top: 14px;
}
.resumo-ia h3 { color: var(--cor-escura); margin-bottom: 10px; font-size: 22px; }
.resumo-ia ul { padding-left: 20px; line-height: 1.7; }
.resumo-ia strong { background: var(--cor-suave); padding: 1px 6px; border-radius: 4px; color: var(--cor-escura); }
.resumo-ia p { line-height: 1.6; margin-bottom: 12px; }
.resumo-ia li { margin-bottom: 6px; line-height: 1.5; }

.pulsar-icone { animation: pulsar-gentil 1.5s ease-in-out infinite; }
@keyframes pulsar-gentil { 0%, 100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.15); opacity: 0.7; } }

/* histórico */
.historico-item {
  background: var(--cor-bebe);
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  margin-bottom: 10px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 0.2s;
}
.historico-item:hover { border-color: var(--cor-suave); transform: translateX(4px); }
.historico-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.historico-tema { font-size: 14px; font-weight: 600; color: var(--texto-principal); margin-bottom: 6px; line-height: 1.3; }
.historico-meta { font-size: 11px; color: var(--texto-suave); }
.tag-materia { background: var(--cor-suave); color: var(--cor-escura); padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: 0.4px; display: inline-block; }
.tag-professor { background: #FFF4E0; color: #9C6F15; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; display: inline-block; }
.resumo-meta-header { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px dashed var(--cor-suave); }

.filtros-chips { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.filtros-label { font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--texto-suave); font-weight: 700; margin-right: 4px; }
.chip { background: white; border: 1.5px solid var(--cor-suave); color: var(--cor-escura); padding: 6px 14px; border-radius: 999px; font-size: 12px; font-family: inherit; font-weight: 600; cursor: pointer; transition: all 0.15s; }
.chip:hover { border-color: var(--cor-principal); background: var(--cor-bebe); }
.chip.ativo { background: var(--cor-principal); border-color: var(--cor-principal); color: white; }

.historico-postits-badge { display: inline-block; background: #FFF59D; color: #9C6F15; padding: 2px 8px; border-radius: 999px; font-size: 10px; font-weight: 700; letter-spacing: 0.5px; margin-right: 6px; }

/* post-its */
.postits-section { background: #FFFDF0; border: 1.5px dashed var(--dourado-claro); border-radius: var(--radius-sm); padding: 16px; margin-bottom: 18px; }
.postits-titulo { font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px; color: #9C6F15; font-weight: 700; margin-bottom: 12px; }
.postit { background: linear-gradient(135deg, #FFF9C4 0%, #FFF59D 100%); padding: 14px 36px 12px 16px; border-radius: 10px; margin-bottom: 10px; box-shadow: 0 3px 8px rgba(201, 169, 97, 0.22); position: relative; font-size: 14px; color: #5D4A2E; line-height: 1.5; white-space: pre-wrap; word-break: break-word; border-left: 4px solid #F5D98E; }
.postit-data { font-size: 10px; color: #9C6F15; margin-top: 8px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; opacity: 0.8; }
.postit-remover { position: absolute; top: 6px; right: 6px; background: transparent; border: none; color: #9C6F15; cursor: pointer; font-size: 18px; padding: 4px 10px; opacity: 0.5; line-height: 1; border-radius: 8px; }
.postit-remover:hover { opacity: 1; color: var(--cor-principal); background: rgba(255,255,255,0.5); }
.postit-novo { margin-top: 12px; display: flex; gap: 8px; align-items: stretch; }
.postit-novo textarea { flex: 1; padding: 10px 12px; border: 2px solid var(--dourado-claro); border-radius: 10px; font-family: inherit; font-size: 13px; resize: vertical; min-height: 50px; background: white; outline: none; color: var(--texto-principal); font-weight: 500; }
.postit-novo textarea:focus { border-color: var(--dourado); }
.postit-novo button { background: linear-gradient(135deg, #C9A961 0%, #B38A3E 100%); color: white; border: none; padding: 0 18px; border-radius: 10px; font-family: inherit; font-size: 12px; font-weight: 700; cursor: pointer; white-space: nowrap; }
.postits-vazio { font-size: 13px; color: var(--texto-suave); font-style: italic; padding: 8px 4px; text-align: center; }

@media (max-width: 480px) {
  .postit-novo { flex-direction: column; }
  .postit-novo button { padding: 12px 20px; }
}

/* ============ NAVEGAÇÃO INFERIOR ============ */
.nav-inferior {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(180deg, white 0%, var(--cor-bebe) 100%);
  border-top: 2px solid var(--cor-bebe);
  display: flex;
  justify-content: space-around;
  padding: 10px 0 calc(10px + env(safe-area-inset-bottom));
  box-shadow: 0 -6px 24px rgba(0,0,0,0.06);
  z-index: 100;
}
.nav-btn {
  background: none; border: none;
  padding: 8px 12px;
  cursor: pointer;
  display: flex; flex-direction: column;
  align-items: center; gap: 4px;
  color: var(--texto-suave);
  font-family: inherit;
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.4px;
  transition: color 0.2s;
  min-width: 60px;
  border-radius: 12px;
}
.nav-btn.ativo { color: var(--cor-principal); background: var(--cor-bebe); }
.nav-btn .icone { font-size: 24px; }

/* ============ SEÇÕES ============ */
.secao { display: none; animation: fadeIn 0.3s ease; }
.secao.ativa { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

.vazio { text-align: center; padding: 28px 18px; color: var(--texto-suave); font-size: 13px; font-style: italic; }
.ornamento { text-align: center; margin: 18px 0 10px; color: var(--dourado); font-size: 20px; letter-spacing: 14px; opacity: 0.85; }

.frase-foco-decorativa {
  text-align: center;
  padding: 0 20px 24px;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 19px;
  color: var(--cor-escura);
  font-weight: 500;
  line-height: 1.5;
}

/* ============ AGENDA HEADER + BOTÃO + ============ */
.agenda-header { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 14px; }
.agenda-header .card-titulo { margin-bottom: 0 !important; }

.botao-adicionar-evento {
  background: linear-gradient(135deg, var(--cor-principal) 0%, var(--cor-escura) 100%);
  color: white;
  border: none;
  padding: 9px 14px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  box-shadow: var(--sombra-suave);
  letter-spacing: 0.4px;
  white-space: nowrap;
}
.botao-adicionar-evento:hover { transform: translateY(-1px); }

/* ============ TREINOS ============ */
.treino-hoje {
  background: linear-gradient(135deg, #FFF4E8 0%, var(--cor-bebe) 100%);
  border: 2px solid var(--dourado-claro);
  border-radius: var(--radius);
  padding: 20px 20px 16px;
  margin-bottom: 20px;
  box-shadow: var(--sombra-suave);
}
.treino-hoje-label { font-size: 12px; text-transform: uppercase; letter-spacing: 2.5px; color: var(--dourado); font-weight: 700; margin-bottom: 12px; }

.treino-item-hoje {
  background: white;
  border-radius: 14px;
  padding: 12px 14px;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  border-left: 4px solid var(--dourado);
}
.treino-item-hoje:last-child { margin-bottom: 0; }
.treino-item-hoje.feito { background: linear-gradient(90deg, #E8F5E9 0%, white 100%); border-left-color: var(--verde-sucesso); opacity: 0.88; }
.treino-item-hoje.feito .treino-nome { text-decoration: line-through; color: var(--texto-suave); }
.treino-icone { font-size: 28px; flex-shrink: 0; }
.treino-info { flex: 1; min-width: 0; }
.treino-nome { font-size: 15px; font-weight: 700; color: var(--texto-principal); margin-bottom: 2px; line-height: 1.3; }
.treino-hora { font-size: 12px; color: var(--cor-principal); font-weight: 600; }
.treino-item-hoje.feito .treino-hora { color: var(--verde-sucesso); }

.treino-feito-btn {
  background: var(--cor-bebe);
  border: 2.5px solid var(--cor-suave);
  width: 40px; height: 40px;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 20px;
  color: var(--cor-escura);
  padding: 0; font-weight: bold;
}
.treino-item-hoje.feito .treino-feito-btn { background: var(--verde-sucesso); border-color: var(--verde-sucesso); color: white; }

.treino-rotina-item { background: var(--cor-bebe); border-radius: var(--radius-sm); padding: 12px 14px; margin-bottom: 10px; display: flex; align-items: center; gap: 12px; }
.treino-rotina-icone { font-size: 26px; flex-shrink: 0; }
.treino-rotina-info { flex: 1; min-width: 0; }
.treino-rotina-nome { font-size: 14px; font-weight: 700; color: var(--texto-principal); margin-bottom: 6px; line-height: 1.3; }
.treino-rotina-detalhes { font-size: 12px; color: var(--texto-suave); font-weight: 600; display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.treino-rotina-dia { display: inline-block; background: var(--cor-suave); color: var(--cor-escura); padding: 3px 9px; border-radius: 999px; font-size: 10px; font-weight: 700; letter-spacing: 0.4px; }
.treino-rotina-hora { color: var(--cor-principal); margin-left: 4px; }

.treino-stats { text-align: center; padding: 12px 14px; background: linear-gradient(90deg, var(--cor-bebe) 0%, #FFF4E8 100%); border-radius: var(--radius-sm); margin-top: 14px; font-size: 13px; color: var(--texto-principal); font-weight: 600; border: 1.5px dashed var(--dourado-claro); }
.treino-stats strong { color: var(--cor-principal); font-size: 16px; }

.dias-semana-opcoes { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.dia-semana-btn {
  aspect-ratio: 1;
  border-radius: 50%;
  border: 2px solid var(--cor-suave);
  background: white;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  color: var(--texto-principal);
  cursor: pointer;
  padding: 0;
  min-height: 38px;
}
.dia-semana-btn.selecionado { background: var(--cor-principal); border-color: var(--cor-principal); color: white; transform: scale(1.06); }

/* ============ MODAL ============ */
.modal-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 200;
  display: none;
  align-items: center; justify-content: center;
  padding: 20px;
}
.modal-overlay.aberto { display: flex; animation: fadeIn 0.2s ease; }

.modal-conteudo {
  background: linear-gradient(180deg, white 0%, var(--cor-bebe) 100%);
  border-radius: var(--radius);
  padding: 26px 22px;
  max-width: 440px;
  width: 100%;
  box-shadow: var(--sombra-forte);
  max-height: 90vh;
  overflow-y: auto;
  border: 1px solid var(--cor-suave);
}

.modal-titulo { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 26px; color: var(--cor-escura); font-weight: 700; text-align: center; margin-bottom: 6px; }
.modal-subtitulo { font-size: 12px; color: var(--texto-suave); text-align: center; margin-bottom: 20px; font-style: italic; }

.campo { margin-bottom: 16px; }
.campo-linha { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.campo-label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--cor-escura); font-weight: 700; margin-bottom: 6px; }

.campo-tipos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.campo-tipo-opcao { padding: 10px 6px; border-radius: 12px; border: 2px solid var(--cor-suave); background: white; font-family: inherit; font-size: 12px; font-weight: 600; color: var(--texto-principal); cursor: pointer; transition: all 0.15s; }
.campo-tipo-opcao.selecionado { border-color: var(--cor-principal); background: var(--cor-suave); color: var(--cor-escura); }

.campo-icones { display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px; }
.campo-icone-opcao { aspect-ratio: 1; border-radius: 8px; border: 2px solid var(--cor-suave); background: white; font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0; font-family: inherit; }
.campo-icone-opcao.selecionado { border-color: var(--cor-principal); background: var(--cor-suave); transform: scale(1.08); }

.campo-cores-aula { display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px; }
.cor-aula-opcao { aspect-ratio: 1; border-radius: 50%; border: 2.5px solid white; cursor: pointer; padding: 0; box-shadow: 0 0 0 1.5px var(--cor-suave); transition: transform 0.12s; }
.cor-aula-opcao.selecionado { transform: scale(1.15); box-shadow: 0 0 0 3px var(--cor-principal); }

.modal-acoes { display: flex; gap: 10px; margin-top: 22px; flex-wrap: wrap; }
.modal-acoes .botao { flex: 1; padding: 12px 16px; min-width: 80px; }

@media (max-width: 480px) {
  .campo-icones { grid-template-columns: repeat(6, 1fr); }
  .campo-tipos { grid-template-columns: 1fr; }
  .agenda-header { flex-direction: column; align-items: flex-start; }
  .botao-adicionar-evento { align-self: flex-end; }
}

/* ============ GRADE HORÁRIA ============ */
.grade-semana { display: flex; flex-direction: column; gap: 14px; }
.grade-dia { background: #FFFBF7; border-radius: 14px; padding: 14px 14px 10px; border: 1px solid var(--cor-suave); }
.grade-dia.dia-hoje { background: linear-gradient(135deg, #FFF8EC 0%, var(--cor-bebe) 100%); border: 2px solid var(--dourado); box-shadow: 0 2px 10px rgba(212, 175, 55, 0.18); }
.grade-dia-titulo { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 700; color: var(--cor-escura); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.grade-dia-titulo .hoje-marca { font-size: 9px; text-transform: uppercase; background: var(--dourado); color: white; padding: 3px 9px; border-radius: 20px; font-family: 'Quicksand', sans-serif; font-weight: 700; letter-spacing: 1px; }

.aula-card { background: white; border-radius: 12px; padding: 11px 13px; margin-bottom: 8px; border-left: 5px solid var(--cor-principal); box-shadow: 0 1px 4px rgba(0,0,0,0.04); cursor: pointer; transition: transform 0.15s ease; display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.aula-card:active { transform: scale(0.98); }
.aula-card:last-child { margin-bottom: 0; }
.aula-info { flex: 1; min-width: 0; }
.aula-hora { font-size: 11px; color: var(--texto-suave); font-weight: 700; letter-spacing: 0.5px; margin-bottom: 3px; }
.aula-nome { font-size: 14px; color: var(--texto-principal); font-weight: 600; line-height: 1.35; margin-bottom: 3px; }
.aula-detalhes { font-size: 11px; color: var(--texto-suave); line-height: 1.4; margin-top: 4px; }
.aula-detalhes .det-item { display: inline-block; margin-right: 10px; }
.aula-editar-icone { font-size: 14px; opacity: 0.4; flex-shrink: 0; }

/* Cores das aulas */
.aula-card.aula-cor-rosa { border-left-color: #E8799F; }
.aula-card.aula-cor-verde { border-left-color: #7FB77E; }
.aula-card.aula-cor-verde-escuro { border-left-color: #4A7C59; }
.aula-card.aula-cor-azul { border-left-color: #6BA5D1; }
.aula-card.aula-cor-amarelo { border-left-color: #E8C547; }
.aula-card.aula-cor-amarelo-claro { border-left-color: #F0D878; }
.aula-card.aula-cor-roxo { border-left-color: #A87EC9; }
.aula-card.aula-cor-laranja { border-left-color: #E89B5A; }

/* ============ BANNER INSTALAR PWA ============ */
.banner-instalar {
  background: linear-gradient(135deg, var(--cor-principal) 0%, var(--cor-escura) 100%);
  color: white;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 4px 14px rgba(0,0,0,0.15);
}
.banner-icone { font-size: 26px; flex-shrink: 0; }
.banner-texto { flex: 1; min-width: 0; line-height: 1.3; }
.banner-texto strong { display: block; font-size: 13px; font-weight: 700; }
.banner-texto span { font-size: 11px; opacity: 0.92; }
.banner-cta {
  background: white;
  color: var(--cor-escura);
  padding: 7px 14px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  font-size: 12px;
  flex-shrink: 0;
  letter-spacing: 0.3px;
  white-space: nowrap;
}
.banner-fechar {
  background: rgba(255,255,255,0.2);
  border: none;
  color: white;
  width: 28px; height: 28px;
  border-radius: 50%;
  font-size: 18px;
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  font-weight: bold;
}
.banner-fechar:hover { background: rgba(255,255,255,0.35); }

@media (max-width: 480px) {
  .banner-texto span { display: none; }
  .banner-instalar { padding: 10px 12px; gap: 10px; }
  .banner-cta { padding: 6px 12px; font-size: 11px; }
}

/* ============ BACKUP / RESTORE ============ */
.backup-acoes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 8px;
}
.botao-backup {
  font-size: 13px !important;
  padding: 10px 12px !important;
  white-space: nowrap;
}
@media (max-width: 480px) {
  .backup-acoes { grid-template-columns: 1fr; }
}

/* ============ AGENDA — botões + ações ============ */
.agenda-acoes {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.botao-secundario-mini {
  background: white !important;
  color: var(--cor-escura) !important;
  border: 1.5px solid var(--cor-suave) !important;
  box-shadow: none !important;
  font-size: 11px !important;
  padding: 8px 12px !important;
}
.botao-secundario-mini:hover {
  background: var(--cor-bebe) !important;
  border-color: var(--cor-principal) !important;
}

/* ============ IMPORTAR CALENDÁRIO ============ */
.cal-preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  background: var(--cor-bebe);
  border-radius: 12px;
  margin-bottom: 12px;
  font-size: 13px;
  color: var(--texto-principal);
  flex-wrap: wrap;
  gap: 6px;
}
.cal-preview-header strong {
  color: var(--cor-escura);
  font-size: 16px;
}
.cal-preview-acoes-topo {
  display: flex;
  gap: 6px;
}
.cal-mini-btn {
  background: white;
  border: 1px solid var(--cor-suave);
  color: var(--cor-escura);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-family: inherit;
  font-weight: 600;
  cursor: pointer;
}
.cal-mini-btn:hover { background: var(--cor-bebe); }

.cal-preview-lista {
  max-height: 50vh;
  overflow-y: auto;
  border: 1px solid var(--cor-bebe);
  border-radius: 12px;
  padding: 4px;
}
.cal-preview-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--cor-bebe);
  cursor: pointer;
  transition: background 0.15s;
}
.cal-preview-item:last-child { border-bottom: none; }
.cal-preview-item:hover { background: var(--cor-bebe); }
.cal-preview-item input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--cor-principal);
  cursor: pointer;
  flex-shrink: 0;
}
.cal-preview-data {
  background: var(--cor-suave);
  color: var(--cor-escura);
  padding: 4px 8px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  min-width: 56px;
  text-align: center;
}
.cal-preview-item.tipo-prova .cal-preview-data {
  background: var(--cor-principal);
  color: white;
}
.cal-preview-item.tipo-feriado .cal-preview-data {
  background: #E8F5E9;
  color: #2E7D32;
}
.cal-preview-titulo {
  flex: 1;
  min-width: 0;
  font-size: 13px;
  color: var(--texto-principal);
  font-weight: 500;
  line-height: 1.3;
}
.cal-preview-icone {
  font-size: 22px;
  flex-shrink: 0;
}

@media (max-width: 480px) {
  .agenda-acoes { width: 100%; justify-content: stretch; }
  .agenda-acoes button { flex: 1; }
  .cal-preview-titulo { font-size: 12px; }
}

/* ============ NOTAS (calculadora) ============ */
.notas-resumo-geral {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 16px;
}
.notas-resumo-item {
  background: var(--cor-bebe);
  border-radius: var(--radius-sm);
  padding: 10px 8px;
  text-align: center;
}
.notas-resumo-numero {
  font-size: 22px;
  font-weight: 700;
  color: var(--cor-escura);
  line-height: 1;
}
.notas-resumo-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--texto-suave);
  font-weight: 600;
  margin-top: 4px;
}

.materia-notas-card {
  background: white;
  border: 1.5px solid var(--cor-suave);
  border-radius: var(--radius);
  padding: 16px 16px 14px;
  margin-bottom: 12px;
  border-left-width: 5px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}

/* Cores de borda esquerda */
.materia-notas-card.cor-rosa     { border-left-color: #E8799F; }
.materia-notas-card.cor-verde    { border-left-color: #7FB77E; }
.materia-notas-card.cor-azul     { border-left-color: #6BA5D1; }
.materia-notas-card.cor-amarelo  { border-left-color: #E8C547; }
.materia-notas-card.cor-roxo     { border-left-color: #A87EC9; }
.materia-notas-card.cor-laranja  { border-left-color: #E89B5A; }

.materia-notas-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px;
  gap: 10px;
}
.materia-notas-nome {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--texto-principal);
  line-height: 1.2;
  flex: 1;
  min-width: 0;
}
.materia-notas-acoes {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.botao-mini {
  background: var(--cor-bebe);
  border: 1px solid var(--cor-suave);
  color: var(--cor-escura);
  width: 32px; height: 32px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 14px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.botao-mini:hover { background: var(--cor-suave); }

.materia-notas-meta-linha {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  font-size: 12px;
  color: var(--texto-suave);
  flex-wrap: wrap;
}
.status-badge {
  padding: 3px 10px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.status-badge.aprovado     { background: #E8F5E9; color: #2E7D32; }
.status-badge.em-jogo      { background: #FFF8E1; color: #F57C00; }
.status-badge.em-risco     { background: #FFE0B2; color: #E65100; }
.status-badge.reprovado    { background: #FFEBEE; color: #C62828; }
.status-badge.pendente     { background: var(--cor-bebe); color: var(--cor-escura); }

.materia-notas-progresso {
  background: var(--cor-bebe);
  height: 6px;
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: 12px;
}
.materia-notas-progresso-fill {
  height: 100%;
  border-radius: 6px;
  transition: width 0.4s ease;
}
.materia-notas-progresso-fill.aprovado  { background: #66BB6A; }
.materia-notas-progresso-fill.em-jogo   { background: #FFB300; }
.materia-notas-progresso-fill.em-risco  { background: #FB8C00; }
.materia-notas-progresso-fill.reprovado { background: #E53935; }

.aval-linha {
  display: grid;
  grid-template-columns: 1fr 56px 80px;
  gap: 8px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px dashed var(--cor-suave);
}
.aval-linha:last-child { border-bottom: none; }
.aval-nome {
  font-size: 14px;
  font-weight: 600;
  color: var(--texto-principal);
  min-width: 0;
}
.aval-nome small {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: var(--texto-suave);
  margin-top: 1px;
}
.aval-peso {
  font-size: 11px;
  color: var(--texto-suave);
  text-align: center;
  font-weight: 600;
}
.aval-nota-input {
  width: 100%;
  padding: 6px 8px;
  border: 1.5px solid var(--cor-suave);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  font-family: inherit;
  color: var(--cor-escura);
  background: white;
  outline: none;
}
.aval-nota-input:focus { border-color: var(--cor-principal); }
.aval-nota-input.preenchida { background: var(--cor-bebe); }

.materia-notas-conclusao {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--cor-bebe);
  border-radius: 10px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--texto-principal);
}
.materia-notas-conclusao strong { color: var(--cor-escura); }
.materia-notas-conclusao .precisa-tirar {
  font-weight: 700;
  font-size: 14px;
  color: var(--cor-escura);
}
.materia-notas-conclusao.aprovado { background: #E8F5E9; color: #2E7D32; }
.materia-notas-conclusao.aprovado strong { color: #1B5E20; }
.materia-notas-conclusao.reprovado { background: #FFEBEE; color: #C62828; }
.materia-notas-conclusao.reprovado strong { color: #B71C1C; }

/* Modal config de avaliações */
.aval-config-linha {
  display: grid;
  grid-template-columns: 1fr 70px 36px;
  gap: 6px;
  margin-bottom: 6px;
}
.aval-config-linha .input {
  padding: 10px 12px;
  font-size: 14px;
}
.botao-remover-aval {
  background: #FFEBEE;
  border: 1.5px solid #FFCDD2;
  color: #C62828;
  border-radius: 8px;
  cursor: pointer;
  font-size: 18px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.botao-remover-aval:hover { background: #FFCDD2; }

.botao-add-aval { font-size: 13px !important; padding: 10px 14px !important; }

/* Botoes de preset (4 bimestres / 3 trimestres / etc) */
.presets-aval {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  margin-bottom: 12px;
  padding: 10px 12px;
  background: var(--cor-bebe);
  border-radius: 10px;
  border: 1px solid var(--cor-suave);
}
.presets-aval-label {
  font-size: 12px;
  color: var(--texto-suave);
  font-weight: 600;
  margin-right: 4px;
}
.preset-aval-btn {
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: 999px;
  background: white;
  color: var(--cor-escura);
  border: 1px solid var(--cor-suave);
  cursor: pointer;
  transition: all 0.15s;
}
.preset-aval-btn:hover {
  background: var(--cor-principal);
  color: white;
  border-color: var(--cor-principal);
}

/* Toggle "Substituir grade atual" no modal de importar grade */
.grade-substituir-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  margin-top: 14px;
  background: var(--cor-bebe);
  border: 1px solid var(--cor-suave);
  border-radius: 10px;
  cursor: pointer;
  font-size: 13px;
  color: var(--texto-principal);
  line-height: 1.4;
}
.grade-substituir-toggle input[type="checkbox"] {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--cor-principal);
}

@media (max-width: 480px) {
  .notas-resumo-geral { grid-template-columns: repeat(3, 1fr); }
  .aval-linha { grid-template-columns: 1fr 48px 70px; gap: 6px; }
}

/* ============ RESPONSIVO ============ */
@media (max-width: 480px) {
  body { font-size: 16px; }
  .header .nome { font-size: 40px; }
  .countdown .dias { font-size: 64px; }
  .mensagem-do-dia .texto { font-size: 19px; }
  .pomodoro-timer { font-size: 70px; }
  .versiculo-texto { font-size: 18px; }
}

@media (min-width: 768px) {
  .app { padding: 0 40px; max-width: 800px; }
  .header { padding: 50px 20px 40px; }
  .header .nome { font-size: 60px; }
  .card { padding: 30px 26px; }
  .countdown { padding: 38px 28px; }
  .countdown .dias { font-size: 96px; }
  .mensagem-do-dia .texto { font-size: 25px; }
  .versiculo-texto { font-size: 24px; }
  .aula-nome { font-size: 15px; }
  .grade-dia-titulo { font-size: 20px; }
}

/* ============ TELA DE ATIVAÇÃO ============ */
.tela-ativacao {
  position: fixed;
  inset: 0;
  background: linear-gradient(135deg, #FFF0F5 0%, #F5D5E0 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 9999;
  overflow-y: auto;
}
.ativacao-card {
  background: white;
  border-radius: 28px;
  padding: 40px 28px;
  max-width: 460px;
  width: 100%;
  box-shadow: 0 18px 50px rgba(232, 121, 159, 0.18);
  text-align: center;
}
.ativacao-emoji {
  font-size: 56px;
  margin-bottom: 14px;
}
.ativacao-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 30px;
  font-weight: 700;
  color: #C85C85;
  margin-bottom: 8px;
  line-height: 1.2;
}
.ativacao-subtitulo {
  color: #666;
  font-size: 15px;
  line-height: 1.5;
  margin-bottom: 28px;
}
.ativacao-campo {
  text-align: left;
  margin-bottom: 18px;
}
.ativacao-campo label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #555;
  margin-bottom: 6px;
}
.ativacao-campo input {
  width: 100%;
  padding: 16px 18px;
  border: 2px solid #F5D5E0;
  border-radius: 14px;
  font-size: 18px;
  font-family: 'Courier New', monospace;
  font-weight: 700;
  text-align: center;
  letter-spacing: 1px;
  color: #C85C85;
  outline: none;
  text-transform: uppercase;
  transition: border-color 0.2s;
  -webkit-appearance: none;
}
.ativacao-campo input:focus { border-color: #E8799F; }
.botao-ativacao {
  width: 100%;
  padding: 16px;
  background: linear-gradient(135deg, #E8799F, #C85C85);
  color: white;
  border: none;
  border-radius: 999px;
  font-size: 17px;
  font-weight: 700;
  font-family: 'Quicksand', sans-serif;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  box-shadow: 0 8px 22px rgba(232, 121, 159, 0.35);
}
.botao-ativacao:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(232, 121, 159, 0.45); }
.botao-ativacao:disabled { opacity: 0.5; cursor: wait; transform: none; box-shadow: none; }
.ativacao-erro {
  color: #C62828;
  font-size: 13px;
  margin-top: 12px;
  min-height: 18px;
  font-weight: 600;
}
.ativacao-spinner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 14px;
  color: #C85C85;
  font-size: 13px;
  font-weight: 600;
}
.spinner-circ {
  width: 16px;
  height: 16px;
  border: 2.5px solid #F5D5E0;
  border-top-color: #C85C85;
  border-radius: 50%;
  animation: spinner-girar 0.8s linear infinite;
}
@keyframes spinner-girar { to { transform: rotate(360deg); } }
.ativacao-rodape {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px dashed #F5D5E0;
  font-size: 12px;
  color: #888;
  line-height: 1.6;
}
.ativacao-rodape a { color: #C85C85; font-weight: 600; text-decoration: none; }
.ativacao-rodape a:hover { text-decoration: underline; }
.ativacao-rodape-comprar {
  margin-top: 12px;
  padding-top: 12px;
}
