@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600&family=Montserrat:wght@600;700;800&display=swap');

*{
box-sizing:border-box;
}

html{
scroll-behavior:smooth;
}

body{
margin:0;
background:#131313;
color:white;
font-family:"Open Sans",sans-serif;
font-size:16px;
line-height:32px;
}

/* HEADER */

.topbar{
background:#131313;
display:flex;
align-items:center;
justify-content:space-between;
padding:18px 40px;
border-bottom:1px solid #B2D819;
position:relative;
z-index:1000;
}

.logo{
height:22px;
width:auto;
}

.menu{
display:flex;
align-items:center;
gap:25px;
}

.menu a{
color:white;
text-decoration:none;
font-size:15px;
}

.menu a:hover{
color:#B2D819;
}

.menu-admin{

color:#B2D819 !important;

}

.menu-admin:hover{

color:#d4ff3f !important;

}

/* DROPDOWN */

.dropdown{
position:relative;
z-index:1001;
}

.dropdown-content{
display:none;
position:absolute;
top:28px;
background:#1A1A1A;
border-radius:6px;
padding:10px 0;
min-width:180px;
box-shadow:0 10px 25px rgba(0,0,0,0.4);
z-index:1002;
}

.dropdown-content a{
display:block;
padding:10px 20px;
}

.dropdown:hover .dropdown-content{
display:block;
}

/* HERO */

.hero{
text-align:center;
padding:120px 20px 80px;
max-width:900px;
margin:auto;
}

.hero h1{
font-family:"Montserrat",sans-serif;
font-size:46px;
margin-bottom:10px;
}

.hero p{
opacity:0.85;
}

.btn{
display:inline-block;
margin-top:30px;
padding:14px 32px;
background:#B2D819;
color:#131313;
text-decoration:none;
border-radius:6px;
font-weight:bold;
transition:0.2s;
}

.btn:hover{
opacity:0.85;
transform:translateY(-1px);
}

/* FEATURES */

.features{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
max-width:1100px;
margin:80px auto;
}

.feature{

position:relative;

background:#1A1A1A;

padding:35px;

border-radius:10px;

text-align:center;

display:flex;
flex-direction:column;
justify-content:space-between;

min-height:220px;

box-shadow:0 4px 14px rgba(0,0,0,0.25);

transition:all 0.25s ease;

}

.feature:hover{

box-shadow:
0 10px 30px rgba(0,0,0,0.45),
0 0 8px rgba(178,216,25,0.15);

transform:translateY(-4px);

}

.feature h3{
font-family:"Montserrat",sans-serif;
color:#B2D819;
margin-bottom:10px;
}

.feature .btn{
margin-top:20px;
}

/* COURSE STATUS */

.course-status{

position:absolute;

top:14px;
right:14px;

width:8px;
height:8px;

border-radius:50%;

opacity:0.85;

}

.status-complete{

background:#B2D819;

box-shadow:0 0 4px rgba(178,216,25,0.7);

}

.status-dev{

background:#e6c15a;

box-shadow:0 0 4px rgba(230,193,90,0.6);

}

/* REPOSITORIO */

.repo-container{
max-width:1100px;
margin:auto;
padding:60px 20px;
}

.manual-card{
background:#1A1A1A;
padding:35px;
border-radius:10px;
max-width:500px;
margin:auto;
text-align:center;
}

.repo-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:25px;
margin-top:60px;
}

.repo-card{
background:#1A1A1A;
padding:30px;
border-radius:10px;
}

.repo-card h3{
font-family:"Montserrat",sans-serif;
color:#B2D819;
text-align:center;
margin-bottom:15px;
}

.repo-card p{
color:white;
text-align:left;
line-height:26px;
margin-bottom:20px;
}

.repo-card a{
display:block;
background:#B2D819;
color:#131313;
padding:10px 18px;
border-radius:6px;
text-decoration:none;
text-align:center;
width:140px;
margin:auto;
font-weight:bold;
}

/* EXERCICIOS */

.exercise-layout{
display:flex;
max-width:1200px;
margin:auto;
padding:40px 20px;
}

.sidebar{
width:220px;
position:sticky;
top:120px;
height:fit-content;
}

.sidebar a{
display:block;
margin-bottom:12px;
color:white;
text-decoration:none;
}

.sidebar a:hover{
color:#B2D819;
}

.exercise-content{
flex:1;
padding-left:40px;
}

.exercise-content h1{
font-family:"Montserrat",sans-serif;
}

.exercise-content h2{
font-family:"Montserrat",sans-serif;
color:#B2D819;
margin-top:40px;
}

/* CODE */

pre{
background:#000;
padding:20px;
border-radius:6px;
overflow-x:auto;
color:#B2D819;
}

/* PROGRESS */

#progress-bar{
position:fixed;
top:0;
left:0;
height:4px;
background:#B2D819;
width:0%;
z-index:999;
}

.menu-ex.active{
color:#B2D819;
font-weight:bold;
}

/* EXERCISE NAV */

.exercise-nav{
position:relative;
margin:80px auto;
max-width:1200px;
height:50px;
}

.exercise-nav a{
background:#B2D819;
color:#131313;
padding:12px 20px;
border-radius:6px;
text-decoration:none;
font-weight:bold;
position:absolute;
transition:0.2s;
}

.exercise-nav a:hover{
transform:translateY(-2px);
}

.exercise-nav a:first-child{
left:280px;
}

.exercise-nav a:last-child{
right:100px;
}

/* ADMIN COURSES */

/* Container do Grid */
.courses-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 25px;
}

/* O item (Label) que envolve o checkbox e o texto */
.course-item {
    display: flex;
    align-items: center; /* Centraliza verticalmente o checkbox e o texto */
    gap: 12px;
    background: #1A1A1A; /* Cor de fundo igual aos cards */
    padding: 12px 16px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.course-item:hover {
    background: #222;
}

/* Estilo do Checkbox */
.course-item input[type="checkbox"] {
    margin: 0; /* Remove margens padrão do navegador que causam desalinhamento */
    width: 18px;
    height: 18px;
    accent-color: #B2D819;
    cursor: pointer;
    flex-shrink: 0; /* Garante que o checkbox não amasse se o texto for longo */
}

/* Estilo do Texto */
.course-item span {
    color: white;
    font-size: 15px;
    line-height: 1; /* Mantém a altura da linha controlada */
    user-select: none; /* Evita selecionar o texto ao clicar rápido */
}

/* Destaque quando selecionado */
.course-item:has(input:checked) {
    border-color: #B2D819;
    background: rgba(178, 216, 25, 0.05);
}

.course-item:active{

transform:scale(0.98);

}


.user-highlight{

color:#B2D819;

font-weight:bold;

background:rgba(178,216,25,0.08);

padding:4px 10px;

border-radius:6px;

}

.admin-input{

width:100%;
padding:12px;

background:#111;
border:1px solid #333;

color:white;

border-radius:6px;

font-size:14px;

margin-bottom:20px;

}

.admin-input:focus{

outline:none;

border-color:#B2D819;

}

/* FILE BUTTON */

.file-upload{

display:inline-block;

background:#111;

border:1px solid #333;

padding:12px 18px;

border-radius:6px;

cursor:pointer;

color:white;

transition:0.2s;

margin-bottom:25px;

}

.file-upload:hover{

border-color:#B2D819;

}

.file-upload input{

display:none;

}

/* botão file */

.file-upload span{

font-weight:bold;

}

/* upload box */

.upload-box{

background:#1A1A1A;

padding:40px;

border-radius:10px;

max-width:520px;

box-shadow:0 10px 30px rgba(0,0,0,0.4);

}

.file-name{

margin-top:10px;

font-size:14px;

color:#aaa;

}

.file-selected{

color:#B2D819;

font-weight:bold;

}

.repo-delete{

display:block;

margin-top:10px;

background:#ff4d4d;

color:white;

padding:8px;

border-radius:6px;

text-decoration:none;

text-align:center;

font-size:13px;

transition:0.2s;

}

.repo-delete:hover{

background:#ff2e2e;

}

/* ADMIN UI SYSTEM */

.admin-container{

max-width:900px;
margin:auto;
padding:40px 20px;

}

.admin-card{

background:#1A1A1A;
padding:35px;
border-radius:12px;

box-shadow:
0 10px 25px rgba(0,0,0,0.35);

margin-bottom:30px;

}

.admin-title{

font-family:"Montserrat";
margin-bottom:25px;

}

.admin-form{

display:flex;
flex-direction:column;
gap:18px;

}

.admin-row{

display:flex;
gap:15px;

}

.admin-field{

flex:1;

}

.admin-input{

flex:1;

padding:12px;

background:#111;

border:1px solid #333;

border-radius:8px;

color:white;

font-size:14px;

}

.admin-input:focus{

outline:none;

border-color:#B2D819;

box-shadow:0 0 6px rgba(178,216,25,0.3);

}

.admin-select{

padding:12px;

background:#111;

border:1px solid #333;

border-radius:8px;

color:white;

width:100%;

}

.admin-button{

background:#B2D819;

color:#131313;

padding:14px;

border:none;

border-radius:8px;

font-weight:bold;

cursor:pointer;

transition:.2s;

}

.admin-button:hover{

transform:translateY(-2px);

box-shadow:
0 6px 18px rgba(178,216,25,0.3);

}

.btn-create{

display:inline-block;
min-height:42px;
background:#B2D819;
color:#131313;
padding:12px 20px;
border-radius:8px;
font-weight:bold;
text-decoration:none;
transition:.2s;
border:none;
cursor:pointer;
line-height:1;
display:inline-flex;
align-items:center;
justify-content:center;

}

.btn-create:hover{

transform:translateY(-2px);

box-shadow:
0 6px 18px rgba(178,216,25,0.3);

}

.btn-edit{

display:inline-flex;
align-items:center;
justify-content:center;
min-height:42px;
min-width:118px;
background:#B2D819;
color:#131313;
padding:8px 16px;
border-radius:6px;
text-decoration:none;
font-weight:bold;
transition:.2s;
border:none;
cursor:pointer;
line-height:1;
font-size:15px;
text-align:center;
font-family:"Open Sans",sans-serif;
appearance:none;
vertical-align:middle;

}

.btn-edit:hover{

transform:translateY(-1px);

}

.btn-delete{

display:inline-flex;
align-items:center;
justify-content:center;
min-height:42px;
min-width:118px;
background:#ff4d4d;
color:white;
padding:8px 16px;
border-radius:6px;
text-decoration:none;
font-weight:bold;
transition:.2s;
border:none;
cursor:pointer;
line-height:1;
font-size:15px;
text-align:center;
font-family:"Open Sans",sans-serif;
appearance:none;
vertical-align:middle;

}

.btn-delete:hover{

background:#ff2e2e;

}

.btn-delete:disabled{

background:#5a5a5a;
cursor:not-allowed;
opacity:.7;

}

.btn-muted{

display:inline-flex;
align-items:center;
justify-content:center;
min-height:42px;
min-width:118px;
background:#4a4a4a;
color:white;
padding:8px 16px;
border-radius:6px;
text-decoration:none;
font-weight:bold;
line-height:1;
font-size:15px;

}

.btn-muted:hover{

background:#5a5a5a;

}

.admin-label{

font-size:14px;

opacity:.7;

}

.admin-divider{

height:1px;

background:#2a2a2a;

margin:25px 0;

}

.admin-success{

color:#B2D819;

background:rgba(178,216,25,.08);

padding:12px;

border-radius:6px;

}

.admin-error{

color:#ff8f8f;
background:rgba(255,77,77,.12);
padding:12px;
border-radius:6px;
margin-bottom:18px;

}

.admin-warning{

color:#e6c15a;

}

.logo-link,
.logo-link:visited,
.logo-link:hover,
.logo-link:active {
  text-decoration: none;
  color: #ffffff;
  display: flex;
  align-items: center;
}

.brand-text{
font-family:'Montserrat', sans-serif;
font-size:22px;
font-weight:700;
letter-spacing:.05em;
color:#ffffff;
line-height:1;
text-transform:none;
transition:.2s;
display:inline-block;
}

.logo-link:hover .brand-text{
color:#B2D819;
transform:translateY(-1px);
}

.logo{
  
  transition:.2s;
  
  }

.logo:hover{

opacity:.8;

transform:scale(1.03);

}

.top-actions{

display:flex;
justify-content:space-between;
align-items:center;
margin-bottom:25px;

}

.back-btn,
.finish-btn{

display:inline-flex;
align-items:center;
justify-content:center;
min-height:44px;
padding:12px 22px;
border-radius:8px;
text-decoration:none;
font-weight:bold;
font-size:14px;

}

.back-btn{

background:#333;
color:white;

}

.back-btn:hover{

background:#444;

}

.finish-btn{

background:#B2D819;
color:#131313;

}

.finish-btn:hover{

transform:translateY(-1px);
box-shadow:0 6px 18px rgba(178,216,25,0.3);

}

.password-field{

position:relative;

}

.password-field .admin-input{

margin-bottom:0;
padding-right:110px;

}

.form-decoy{

position:absolute;
left:-9999px;
width:1px;
height:1px;
opacity:0;
pointer-events:none;

}

.password-toggle{

position:absolute;
right:8px;
top:50%;
transform:translateY(-50%);
min-height:34px;
padding:0 14px;
border:none;
border-radius:6px;
background:#333;
color:white;
font-weight:bold;
cursor:pointer;

}

.password-toggle:hover{

background:#444;

}

.admin-toolbar{

display:flex;
justify-content:flex-start;
align-items:center;
gap:20px;
flex-wrap:wrap;

}

.admin-search{

display:flex;
align-items:center;
gap:12px;
flex-wrap:wrap;
margin-left:auto;

}

.admin-search-input{

min-width:240px;
margin-bottom:0;
min-height:42px;
height:42px;

}


.user-card{

padding:24px 26px;

}

.user-row{

display:flex;
justify-content:space-between;
align-items:center;
gap:20px;

}

.user-details{

display:flex;
flex-direction:column;
gap:6px;

}

.user-headline{

display:flex;
align-items:center;
gap:10px;
flex-wrap:wrap;

}

.user-meta{

line-height:1.5;
opacity:.9;

}

.user-active-badge{

display:inline-flex;
align-items:center;
justify-content:center;
padding:4px 10px;
border-radius:999px;
background:rgba(178,216,25,.12);
color:#B2D819;
font-size:13px;
font-weight:bold;
line-height:1;

}

.user-actions{

display:flex;
gap:12px;
align-items:center;
flex-wrap:wrap;

}

.user-actions form{

margin:0;
display:flex;
align-items:center;

}

.btn-user-action{

width:118px;
height:42px;

}

.test-card{

background:#1A1A1A;
padding:25px;
border-radius:10px;
margin-bottom:25px;

}

.test-actions{

display:flex;
gap:12px;
flex-wrap:wrap;
align-items:center;
margin-top:18px;

}

.test-actions form{

margin:0;
display:flex;

}

.import-choice-grid{

display:grid;
grid-template-columns:repeat(2, minmax(0, 1fr));
gap:18px;

}

.import-choice-card{

display:block;
background:#111;
border:1px solid #2b2b2b;
border-radius:12px;
padding:24px;
text-decoration:none;
color:white;
transition:.2s;

}

.import-choice-card h3{

margin:0 0 10px;
font-family:"Montserrat",sans-serif;
color:#B2D819;

}

.import-choice-card p{

margin:0;
line-height:1.7;
opacity:.86;

}

.import-choice-card:hover{

border-color:#B2D819;
transform:translateY(-2px);
box-shadow:0 10px 24px rgba(0,0,0,0.28);

}

.access-denied-page{

min-height:100vh;
display:flex;
align-items:center;
justify-content:center;
padding:40px 20px;

}

.access-denied-card{

width:100%;
max-width:560px;
background:#1A1A1A;
border-radius:14px;
padding:42px 36px;
box-shadow:0 12px 30px rgba(0,0,0,0.35);
text-align:center;

}

.access-denied-card h1{

margin:0 0 16px;
font-family:"Montserrat",sans-serif;
color:#B2D819;
line-height:1.2;

}

.access-denied-card p{

margin:0 0 24px;
color:rgba(255,255,255,0.82);
line-height:1.7;

}


/* Faz a página ocupar toda a altura */
html, body {
    height: 100%;
}

/* Estrutura principal */
.site {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Conteúdo cresce e empurra o rodapé */
.site-content {
    flex: 1;
}

/* Rodapé fica sempre no fundo */
.site-footer {
    margin-top: auto;
}

/* Paginação admin */
.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin: 28px 0 8px;
}

.page-btn {
    display: inline-flex;
    align-items: center;
    padding: 10px 20px;
    background: #1e1e1e;
    color: #B2D819;
    border: 1px solid rgba(178, 216, 25, 0.3);
    border-radius: 10px;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    transition: background 0.2s, border-color 0.2s;
}

.page-btn:hover {
    background: rgba(178, 216, 25, 0.1);
    border-color: #B2D819;
}

.page-info {
    font-size: 14px;
    color: #999;
}