/* --- Identidade Visual Principal - OCULT.IO (Final) --- */
:root {
  --red-natal: #E84A5F;
  --gold-cool: #FFD166;
  --ice-blue: #A7C7E7;
  --snow-white: #F8F9FA;
  --text-muted: #aaa;
  --deep-blue: #1B263B;
  --darker-blue: #151E2D;
  --borda-suave: rgba(232, 74, 95, 0.2);
}

/* --- Reset Básico e Configurações Globais --- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Poppins', sans-serif; background-color: var(--deep-blue); color: var(--snow-white); line-height: 1.7; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
a { color: var(--gold-cool); text-decoration: none; transition: opacity 0.3s ease; }
a:hover { opacity: 0.8; }

/* --- Estilos Gerais (Cabeçalho, Rodapé, Botões) --- */
.cabecalho { background-color: rgba(21, 30, 45, 0.8); backdrop-filter: blur(10px); padding: 15px 0; border-bottom: 1px solid var(--borda-suave); position: sticky; top: 0; z-index: 100; }
.cabecalho .container { display: flex; justify-content: space-between; align-items: center; }
.logo img { max-height: 40px; }
.cabecalho nav { display: flex; align-items: center; gap: 15px; }
.nav-link { font-weight: 600; color: var(--snow-white); }
.btn-principal, .btn-secundario { padding: 10px 25px; border-radius: 5px; text-decoration: none; font-weight: 700; display: inline-block; text-align: center; transition: all 0.3s ease; cursor: pointer; border: 2px solid var(--red-natal); }
.btn-principal { background-color: var(--red-natal); color: var(--snow-white); }
.btn-principal:hover { background-color: transparent; color: var(--red-natal); }
.btn-secundario { background-color: transparent; color: var(--red-natal); }
.btn-secundario:hover { background-color: var(--red-natal); color: var(--snow-white); }
.rodape { text-align: center; padding: 40px 0; border-top: 1px solid var(--borda-suave); background-color: var(--darker-blue); color: var(--text-muted); }

/* --- Estilos da Landing Page (index.html) --- */
.hero { text-align: center; padding: 100px 0; }
.hero h1 { font-size: 48px; margin-bottom: 15px; color: var(--red-natal); font-weight: 800; }
.hero p { font-size: 18px; max-width: 650px; margin: 0 auto 30px; color: var(--snow-white); font-weight: 300; }
.social-proof-text { margin-top: 25px; font-size: 14px; color: var(--text-muted); font-weight: 300; }
.social-proof-text strong { color: var(--gold-cool); font-weight: 600; }
.features { padding: 80px 0; text-align: center; background-color: var(--darker-blue); }
.features h2 { font-size: 36px; margin-bottom: 50px; }
.features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.feature-item { background-color: var(--deep-blue); padding: 30px; border-radius: 8px; }
.feature-icon { width: 50px; height: 50px; line-height: 50px; border-radius: 50%; background-color: var(--red-natal); color: var(--snow-white); font-size: 24px; font-weight: 700; margin: 0 auto 20px; }
.feature-item h3 { font-size: 22px; margin-bottom: 10px; }
.feature-item p { color: var(--text-muted); }
.planos { padding: 80px 0; background-color: var(--deep-blue); text-align: center; }
.planos h2 { font-size: 36px; margin-bottom: 50px; }
.planos-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; align-items: start; }
.plano-card { background-color: var(--darker-blue); padding: 40px; border-radius: 8px; border: 1px solid rgba(232, 74, 95, 0.3); text-align: left; transition: transform 0.3s ease, box-shadow 0.3s ease; }
.plano-card:hover { transform: translateY(-5px); box-shadow: 0 10px 30px rgba(232, 74, 95, 0.1); }
.plano-card.destaque { border-color: var(--red-natal); border-width: 2px; }
.plano-card h3 { font-size: 24px; margin-bottom: 15px; color: var(--snow-white); }
.plano-card .preco { font-size: 28px; font-weight: 700; color: var(--gold-cool); margin-bottom: 20px; }
.plano-card ul { list-style: none; margin-bottom: 30px; }
.plano-card ul li { margin-bottom: 10px; }
.testimonials { padding: 80px 0; background-color: var(--darker-blue); }
.testimonials h2 { text-align: center; font-size: 36px; margin-bottom: 50px; }
.testimonials-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.testimonial-card { background-color: var(--deep-blue); padding: 30px; border-radius: 8px; border-left: 4px solid var(--red-natal); }
.testimonial-card p { font-style: italic; color: var(--text-muted); margin-bottom: 15px; }
.testimonial-card strong { color: var(--snow-white); }
.faq { padding: 80px 0; }
.faq h2 { text-align: center; font-size: 36px; margin-bottom: 50px; }
.faq-container { max-width: 700px; margin: 0 auto; }
.faq-item { margin-bottom: 10px; border-bottom: 1px solid var(--borda-suave); }
.faq-question { background: none; border: none; width: 100%; text-align: left; padding: 20px; font-size: 18px; font-weight: 600; color: var(--snow-white); cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
.faq-question::after { content: '+'; font-size: 24px; color: var(--red-natal); transition: transform 0.3s ease; }
.faq-item.active .faq-question::after { transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; }
.faq-answer p { padding: 0 20px 20px; color: var(--text-muted); }

/* --- Estilos das Páginas de Autenticação e Juntar --- */
.auth-container { display: flex; justify-content: center; align-items: center; min-height: 100vh; padding: 20px; background-color: var(--deep-blue); }
.auth-card { background: var(--darker-blue); padding: 40px; border-radius: 8px; box-shadow: 0 4px 25px rgba(0,0,0,0.3); width: 100%; max-width: 450px; text-align: center; border-top: 4px solid var(--red-natal); }
.auth-card h2 { margin-bottom: 10px; color: var(--snow-white); font-weight: 300; }
.auth-subtext { margin-bottom: 25px; color: var(--text-muted); font-size: 14px; }
.form-group { margin-bottom: 20px; text-align: left; }
.form-group label { display: block; margin-bottom: 8px; font-weight: 600; color: var(--text-muted); font-size: 14px; }
.form-group input { width: 100%; padding: 12px; border: 1px solid #333; border-radius: 5px; font-size: 16px; background-color: var(--deep-blue); color: var(--snow-white); }
.form-group input:focus { border-color: var(--red-natal); outline: none; }
.form-extra { text-align: right; margin-bottom: 15px; font-size: 14px; }
.auth-btn { width: 100%; margin-top: 10px; padding: 12px; font-size: 16px; }
.auth-card p { margin-top: 20px; color: var(--text-muted); }
.invite-title { color: var(--gold-cool); font-size: 28px; font-weight: 700; margin-bottom: 20px; word-break: break-word; }
.join-list-container .join-participant { background-color: rgba(232, 74, 95, 0.1); color: var(--red-natal); border: 1px solid var(--red-natal); padding: 15px; border-radius: 5px; margin-bottom: 10px; text-align: center; font-weight: 600; cursor: pointer; transition: all 0.3s ease; }
.join-list-container .join-participant:hover { background-color: var(--red-natal); color: var(--snow-white); }
.join-list-container .join-participant.is-me { background-color: var(--gold-cool); color: var(--deep-blue); border-color: var(--gold-cool); }
#join-list-title { margin-top: 30px; margin-bottom: 15px; font-size: 18px; color: var(--text-muted); text-align: center; }

/* --- Estilos do Painel (Dashboard) --- */
.dashboard-main { padding: 60px 0; }
#user-greeting { color: var(--snow-white); font-weight: 600; margin-right: 15px; }
.dashboard-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 40px; }
.dashboard-header h2 { font-weight: 700; font-size: 28px; }
a.grupo-card { text-decoration: none; }
.grupos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; min-height: 100px; }
.grupo-card { position: relative; background-color: var(--darker-blue); padding: 20px; border-radius: 8px; border-left: 5px solid var(--red-natal); transition: transform 0.3s ease, box-shadow 0.3s ease; }
.grupo-card:hover { transform: translateY(-5px); box-shadow: 0 10px 30px rgba(0,0,0,0.2); }
.grupo-card h3 { margin-bottom: 10px; color: var(--snow-white); }
.grupo-card p { color: #aaa; font-size: 14px; margin-bottom: 5px; }
.grupo-card strong { color: var(--snow-white); }
.delete-button { position: absolute; top: 10px; right: 15px; background: none; border: none; font-size: 24px; color: #555; cursor: pointer; transition: color 0.3s ease; padding: 5px; line-height: 1; }
.delete-button:hover { color: var(--red-natal); }
.plan-badge { font-weight: 700; padding: 4px 10px; border-radius: 50px; font-size: 12px; margin-right: 15px; text-transform: uppercase; }
.plan-badge.free { background-color: var(--ice-blue); color: var(--deep-blue); }
.plan-badge.premium { background-color: var(--gold-cool); color: var(--deep-blue); }
.group-info { display: flex; justify-content: space-between; align-items: center; margin-top: 15px; padding-top: 15px; border-top: 1px solid #333; }
.participant-count { display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; color: var(--text-muted); }
.participant-count svg { fill: var(--text-muted); }
.premium-banner { background: var(--darker-blue); border: 1px solid var(--borda-suave); border-radius: 8px; padding: 40px; margin-top: 60px; display: grid; grid-template-columns: 2fr 1fr; align-items: center; gap: 40px; }
.premium-pitch h3 { color: var(--gold-cool); font-size: 24px; margin-bottom: 20px; display: flex; align-items: center; gap: 10px; }
.premium-features { list-style: none; padding-left: 0; }
.premium-features li { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; color: var(--text-muted); }
.premium-features svg { fill: var(--gold-cool); flex-shrink: 0; }
.premium-action { text-align: center; display: flex; flex-direction: column; gap: 15px; }
.premium-price { font-size: 18px; font-weight: 700; color: var(--snow-white); }
.disclaimer-text { font-size: 12px; color: var(--text-muted); line-height: 1.4; max-width: 250px; margin: 0 auto; }

/* --- Modais --- */
.modal, .action-modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0,0,0,0.8); backdrop-filter: blur(5px); justify-content: center; align-items: center; }
.modal-content, .action-modal-content { background-color: var(--darker-blue); margin: auto; padding: 30px; border: 1px solid #333; width: 80%; max-width: 500px; border-radius: 8px; position: relative; border-top: 4px solid var(--red-natal); }
.modal-content h2, .action-modal-content p { color: var(--snow-white); }
.close-button { color: #aaa; position: absolute; top: 10px; right: 20px; font-size: 28px; font-weight: bold; cursor: pointer; }
.close-button:hover, .close-button:focus { color: var(--snow-white); }
.action-modal-content p { font-size: 18px; margin-bottom: 20px; }
.action-modal-content input { width: 100%; padding: 10px; border: 1px solid #444; border-radius: 5px; margin-bottom: 20px; font-size: 16px; background-color: var(--deep-blue); color: var(--snow-white); }
.action-modal-content input:focus { border-color: var(--red-natal); outline: none; }
.action-modal-buttons { display: flex; justify-content: center; gap: 15px; }

/* --- Página de Gerenciamento de Grupo --- */
#group-details-container, .draw-section, .invite-link-section, #exclusion-rules-section { background-color: var(--darker-blue); padding: 30px; border-radius: 8px; margin-bottom: 30px; border: 1px solid #333; }
#group-details-container h2 { color: var(--red-natal); }
.divider { border: none; border-top: 1px solid #333; margin: 0 0 30px 0; }
.participants-section h3 { margin-bottom: 20px; font-size: 24px; }
.participant-item { display: flex; justify-content: space-between; align-items: center; background: var(--deep-blue); padding: 15px; border-radius: 5px; margin-bottom: 10px; border-left: 3px solid var(--red-natal); }
.remove-participant-btn { background: none; border: none; color: #555; font-size: 20px; cursor: pointer; transition: color 0.3s ease; }
.remove-participant-btn:hover { color: var(--red-natal); }
.btn-large { padding: 15px 30px; font-size: 18px; font-weight: 700; }
.btn-large:disabled { background-color: #333; border-color: #333; color: #777; cursor: not-allowed; }
.sorteio-resultado { margin-top: 20px; font-size: 18px; font-weight: 300; }
.sorteio-resultado .result-text { color: var(--text-muted); }
.sorteio-resultado .result-name { color: var(--gold-cool); font-size: 32px; display: block; margin-top: 5px; font-weight: 800; }
.invite-link-wrapper input { flex-grow: 1; padding: 10px; border: 1px solid #333; border-radius: 5px; background-color: var(--deep-blue); color: #aaa; font-size: 14px; }
.wishlist-display { margin-top: 25px; text-align: left; border-top: 1px solid var(--borda-suave); padding-top: 20px; }
.wishlist-display h4 { color: var(--gold-cool); margin-bottom: 10px; font-size: 18px; }
.wishlist-display ul { list-style: none; padding-left: 0; }
.wishlist-display li { background-color: var(--deep-blue); padding: 10px; border-radius: 5px; margin-bottom: 8px; color: var(--snow-white); }
#wishlist-section h3 { text-align: center; margin-top: 20px; margin-bottom: 10px; }
.wish-item { display: flex; justify-content: space-between; align-items: center; background: var(--deep-blue); padding: 12px 15px; border-radius: 5px; margin-bottom: 10px; border-left: 3px solid var(--gold-cool); color: var(--snow-white); }
.premium-star { color: var(--gold-cool); margin-right: 5px; }
.rule-form { display: flex; align-items: center; gap: 15px; margin-bottom: 30px; flex-wrap: wrap; }
.rule-form select { flex-grow: 1; padding: 12px; border: 1px solid #333; border-radius: 5px; font-size: 16px; background-color: var(--deep-blue); color: var(--snow-white); min-width: 150px; }
.rule-form span { font-weight: 600; }
.rule-item { display: flex; justify-content: space-between; align-items: center; background: var(--deep-blue); padding: 12px 15px; border-radius: 5px; margin-bottom: 10px; border-left: 3px solid var(--ice-blue); }

/* --- Notificação Global --- */
#global-notification { position: fixed; top: -100px; left: 50%; transform: translateX(-50%); padding: 15px 25px; border-radius: 8px; box-shadow: 0 4px 15px rgba(0,0,0,0.2); font-size: 16px; font-weight: 600; z-index: 2000; transition: top 0.5s ease-in-out; max-width: 90%; text-align: center; }
#global-notification.show { top: 20px; }
#global-notification.success { background-color: var(--ice-blue); color: var(--deep-blue); }
#global-notification.error { background-color: var(--red-natal); color: var(--snow-white); }

/* --- Responsividade --- */
@media (max-width: 820px) {
    .premium-banner { grid-template-columns: 1fr; text-align: center; }
    .premium-pitch h3, .premium-features li { justify-content: center; }
}
@media (max-width: 768px) {
    .features-grid, .testimonials-grid, .planos-grid { grid-template-columns: 1fr; }
    .hero h1 { font-size: 32px; }
    .hero p { font-size: 16px; }
    .dashboard-header { flex-direction: column; gap: 20px; }
}