/* ===========================================================================
   FORJADOS — 40 Dias  |  estilo base (rascunho)
   Tema CLARO. Tipografia: Inter. Acento brasa/fogo para a identidade da forja.
   =========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
    --bg:        #f6f5f2;
    --bg-2:      #efece6;
    --superf:    #ffffff;
    --superf-2:  #faf9f6;
    --borda:     #e4e0d8;
    --borda-2:   #d8d3c8;
    --texto:     #20242c;
    --texto-2:   #6c6c6c;
    --texto-3:   #8a8a8a;
    --brasa:     #c9761a;
    --brasa-2:   #e08a22;
    --fogo:      #c0451b;
    --ouro:      #b08628;
    --verde:     #5e8a3f;
    --sombra:    0 8px 28px rgba(40,33,22,.10);
    --sombra-sm: 0 2px 10px rgba(40,33,22,.06);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    background: var(--bg);
    color: var(--texto);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3 { font-family: 'Inter', sans-serif; font-weight: 800; letter-spacing: -.01em; line-height: 1.15; }
a { color: var(--brasa); text-decoration: none; }
a:hover { color: var(--fogo); }

/* ---------- LOGIN ---------- */
.tela-login {
    display: flex; align-items: center; justify-content: center;
    min-height: 100vh; padding: 24px;
    background: radial-gradient(circle at 50% -20%, #fff7ec 0%, var(--bg) 55%);
}
.login-box {
    width: 100%; max-width: 440px; text-align: center;
    background: var(--superf);
    border: 1px solid var(--borda); border-radius: 16px;
    padding: 48px 34px; box-shadow: var(--sombra);
}
.login-kicker { color: var(--brasa); letter-spacing: 3px; font-size: 11px; font-weight: 700; }
.login-logo {
    font-size: 56px; font-weight: 900; margin: 10px 0 4px; color: var(--texto);
    letter-spacing: -.02em;
}
.login-sub { color: var(--texto-2); font-size: 14px; margin-bottom: 30px; }
.login-form { display: flex; flex-direction: column; gap: 12px; text-align: left; }
.login-form label { font-size: 12px; color: var(--texto-2); text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.login-form input {
    padding: 14px 16px; border-radius: 10px; border: 1px solid var(--borda-2);
    background: var(--superf-2); color: var(--texto); font-size: 16px; font-family: inherit;
}
.login-form input:focus { outline: none; border-color: var(--brasa); box-shadow: 0 0 0 3px rgba(224,138,34,.15); }
.login-erro { color: var(--fogo); font-size: 13px; }
.login-lema { margin-top: 26px; color: var(--texto-3); font-style: italic; font-size: 13px; }

button, .login-form button {
    background: linear-gradient(180deg, var(--brasa-2), var(--fogo));
    color: #fff; border: none; border-radius: 10px;
    padding: 15px 18px; font-weight: 700; letter-spacing: .5px;
    font-size: 15px; cursor: pointer; text-transform: uppercase; font-family: inherit;
    transition: transform .08s ease, filter .15s ease, box-shadow .15s ease;
    box-shadow: 0 6px 16px rgba(192,69,27,.22);
}
button:hover { filter: brightness(1.05); }
button:active { transform: translateY(1px); }

/* ---------- TOPO / RODAPÉ ---------- */
.topbar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 28px; background: rgba(255,255,255,.9); backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--borda); position: sticky; top: 0; z-index: 10;
}
.topbar-logo { font-weight: 900; font-size: 22px; color: var(--texto); letter-spacing: -.01em; }
.topbar-nav { display: flex; gap: 22px; align-items: center; }
.topbar-nav a { color: var(--texto-2); font-size: 14px; font-weight: 500; }
.topbar-nav a:hover { color: var(--brasa); }
.topbar-sair { color: var(--fogo) !important; }

.conteudo { max-width: 860px; margin: 0 auto; padding: 38px 22px 70px; }

.rodape {
    text-align: center; padding: 34px 22px; color: var(--texto-3);
    border-top: 1px solid var(--borda); font-size: 13px; font-style: italic;
}
.rodape-aviso { font-style: normal; font-size: 11px; opacity: .7; margin-top: 8px; }

/* ---------- HERO ---------- */
.hero { text-align: center; padding: 30px 0 24px; }
.hero-compacto { padding: 10px 0 18px; }
.hero-kicker { color: var(--brasa); letter-spacing: 3px; font-size: 12px; font-weight: 700; }
.hero-titulo { font-size: 56px; font-weight: 900; margin: 8px 0; letter-spacing: -.02em; }
.hero-sub { color: var(--texto-2); max-width: 620px; margin: 0 auto; }

/* ---------- TEXTO / PREÂMBULO ---------- */
.texto h2 {
    font-size: 24px; margin: 38px 0 12px; color: var(--texto);
    border-left: 4px solid var(--fogo); padding-left: 14px;
}
.texto p { margin: 12px 0; color: var(--texto); }
.texto strong { color: #000; font-weight: 700; }

.lista-versos, .compromissos, .regra { margin: 14px 0 14px 4px; list-style: none; }
.lista-versos li, .regra li, .compromissos li {
    padding: 9px 0 9px 26px; position: relative; border-bottom: 1px dashed var(--borda-2);
}
.lista-versos li::before, .regra li::before { content: "⚒"; position: absolute; left: 0; color: var(--brasa); }
.compromissos { counter-reset: c; }
.compromissos li { counter-increment: c; }
.compromissos li::before {
    content: counter(c); position: absolute; left: 0; top: 9px;
    color: var(--fogo); font-weight: 800;
}
.lista-versos span { color: var(--texto-3); font-size: 13px; }

.fases-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap: 14px; margin: 18px 0; }
.fase-card { background: var(--superf); border: 1px solid var(--borda); border-radius: 12px; padding: 18px; border-top: 3px solid var(--brasa); box-shadow: var(--sombra-sm); }
.fase-card.f2 { border-top-color: var(--ouro); }
.fase-card.f3 { border-top-color: var(--verde); }
.fase-card.f4 { border-top-color: var(--fogo); }
.fase-card .fase-num { font-size: 11px; color: var(--texto-3); letter-spacing: 1px; font-weight: 600; }
.fase-card h3 { font-size: 22px; margin: 6px 0 8px; }
.fase-card p { font-size: 14px; color: var(--texto-2); }

.verso-destaque, .verso-ancora {
    background: var(--superf-2);
    border-left: 5px solid var(--brasa); border-radius: 10px;
    padding: 22px 26px; margin: 26px 0; font-size: 19px; font-style: italic; color: var(--texto);
    box-shadow: var(--sombra-sm);
}
.verso-destaque cite, .verso-ancora cite { display: block; margin-top: 10px; color: var(--brasa); font-style: normal; font-size: 14px; font-weight: 600; }

/* ---------- PASSOS DE CONDUÇÃO ---------- */
.conducao-passos { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 14px; margin: 20px 0; }
.conducao-passos.vertical { grid-template-columns: 1fr; }
.conducao-passos .passo {
    display: flex; gap: 14px; align-items: flex-start;
    background: var(--superf); border: 1px solid var(--borda); border-radius: 12px;
    padding: 16px 18px; box-shadow: var(--sombra-sm);
}
.conducao-passos .passo > span {
    flex: 0 0 auto; width: 34px; height: 34px; border-radius: 50%;
    background: linear-gradient(180deg, var(--brasa-2), var(--fogo)); color: #fff;
    display: flex; align-items: center; justify-content: center; font-weight: 800;
}
.conducao-passos .passo h3 { font-size: 17px; margin-bottom: 4px; }
.conducao-passos .passo p { font-size: 14px; color: var(--texto-2); margin: 0; }
.conducao-link { margin: 18px 0; font-weight: 600; }

.aceite { margin: 40px 0 10px; text-align: center; background: var(--superf); border: 1px solid var(--borda); border-radius: 14px; padding: 28px; box-shadow: var(--sombra-sm); }
.aceite p { margin-bottom: 16px; font-size: 17px; color: var(--texto); }

/* ---------- GRADE DA JORNADA ---------- */
.fase-bloco { margin: 34px 0; }
.fase-bloco-cab { border-left: 4px solid var(--brasa); padding-left: 14px; margin-bottom: 14px; }
.fase-bloco-cab h2 { font-size: 26px; }
.fase-bloco-num { font-size: 12px; letter-spacing: 2px; color: var(--brasa); font-weight: 600; }
.fase-bloco-cab p { color: var(--texto-2); font-size: 14px; }
.fase-bloco-2 .fase-bloco-cab { border-left-color: var(--ouro); }
.fase-bloco-3 .fase-bloco-cab { border-left-color: var(--verde); }
.fase-bloco-4 .fase-bloco-cab { border-left-color: var(--fogo); }

.dias-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 12px; }
.dia-card {
    background: var(--superf); border: 1px solid var(--borda); border-radius: 12px;
    padding: 16px 14px; display: flex; flex-direction: column; gap: 6px;
    transition: transform .1s ease, border-color .15s ease, box-shadow .15s ease;
    box-shadow: var(--sombra-sm);
}
.dia-card:hover { transform: translateY(-3px); border-color: var(--brasa); box-shadow: var(--sombra); }
.dia-num { font-size: 12px; color: var(--brasa); letter-spacing: 1px; font-weight: 700; }
.dia-nome { font-weight: 700; color: var(--texto); font-size: 15px; }
.dia-tag { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--texto-3); margin-top: auto; }
.dia-tag-ok { color: var(--verde); }
.dia-pronto { border-left: 3px solid var(--brasa); }
.dia-rascunho { opacity: .8; }

/* ---------- PÁGINA DO DIA ---------- */
.dia-breadcrumb { font-size: 13px; color: var(--texto-2); margin-bottom: 14px; }
.dia-cabecalho { text-align: center; margin-bottom: 10px; }
.dia-cabecalho-num { color: var(--brasa); letter-spacing: 3px; font-size: 13px; font-weight: 700; }
.dia-cabecalho h1 { font-size: 44px; font-weight: 900; margin: 6px 0; letter-spacing: -.02em; }
.dia-cabecalho-sub { color: var(--texto-2); font-style: italic; }

.bloco { background: var(--superf); border: 1px solid var(--borda); border-radius: 12px; padding: 20px 22px; margin: 16px 0; box-shadow: var(--sombra-sm); }
.bloco h2 { display: flex; align-items: center; gap: 12px; font-size: 18px; margin-bottom: 8px; color: var(--texto); }
.bloco h2 small { font-size: 13px; color: var(--texto-3); font-weight: 400; }
.bloco p { color: var(--texto); }
.bloco-desafio { border-left: 4px solid var(--fogo); }
.bloco-forja { border-left: 4px solid var(--brasa); background: var(--superf-2); }
.bloco-diario { border-left: 4px solid var(--ouro); }
.bloco-rascunho { border-left: 4px solid var(--texto-3); opacity: .9; }

/* ---------- ÍCONES DOS BLOCOS ---------- */
.bloco-ico {
    flex: 0 0 auto; width: 38px; height: 38px; border-radius: 11px;
    display: inline-flex; align-items: center; justify-content: center;
}
.bloco-ico svg { width: 21px; height: 21px; display: block; }
.ico-brasa { color: var(--brasa); background: rgba(201,118,26,.10); }
.ico-fogo  { color: var(--fogo);  background: rgba(192,69,27,.11); }
.ico-ouro  { color: var(--ouro);  background: rgba(176,134,40,.13); }
.ico-verde { color: var(--verde); background: rgba(94,138,63,.13); }

/* ---------- DESAFIO: PASSO A PASSO ---------- */
.bloco-passos { border-left: 4px solid var(--fogo); }
.passos-lista { list-style: none; counter-reset: passo; margin: 6px 0 0; padding: 0; }
.passos-lista li {
    counter-increment: passo; position: relative;
    padding: 12px 0 12px 44px; border-bottom: 1px dashed var(--borda-2);
}
.passos-lista li:last-child { border-bottom: none; padding-bottom: 2px; }
.passos-lista li::before {
    content: counter(passo); position: absolute; left: 0; top: 11px;
    width: 28px; height: 28px; border-radius: 50%;
    background: linear-gradient(180deg, var(--brasa-2), var(--fogo)); color: #fff;
    font-weight: 800; font-size: 13px;
    display: flex; align-items: center; justify-content: center;
}
.passos-lista li strong { color: #000; }

/* ---------- EXEMPLOS REAIS ---------- */
.bloco-exemplos { border-left: 4px solid var(--brasa); }
.exemplos-intro { font-size: 14px; color: var(--texto-2); margin-bottom: 12px; }
.exemplos-lista { list-style: none; display: grid; gap: 8px; }
.exemplos-lista li {
    position: relative; padding: 9px 14px 9px 36px; font-size: 14px;
    background: var(--superf-2); border: 1px solid var(--borda); border-radius: 9px;
}
.exemplos-lista li::before {
    content: ""; position: absolute; left: 13px; top: 50%; width: 11px; height: 11px;
    margin-top: -5.5px; border-radius: 50%;
    background: var(--fogo); box-shadow: 0 0 0 3px rgba(192,69,27,.14);
}

/* ---------- RITUAL: RASGAR E QUEIMAR ---------- */
.bloco-ritual {
    border-left: 4px solid var(--fogo);
    background: linear-gradient(180deg, #fff6f1, var(--superf));
}
.bloco-ritual p { color: var(--texto); font-size: 15.5px; }

/* ---------- MATERIAIS ---------- */
.bloco-materiais { border-left: 4px solid var(--brasa); background: var(--superf-2); }
.materiais-intro { font-size: 14px; color: var(--texto-2); margin-bottom: 12px; }
.materiais-lista { list-style: none; display: grid; gap: 8px; }
.materiais-lista li {
    position: relative; padding: 9px 14px 9px 38px; font-size: 14px;
    background: var(--superf); border: 1px solid var(--borda); border-radius: 9px;
}
.materiais-lista li::before {
    content: "✓"; position: absolute; left: 14px; top: 50%; margin-top: -10px;
    color: var(--verde); font-weight: 800; font-size: 15px; line-height: 20px;
}

.compromissos-dia { margin: 26px 0; padding: 18px 22px; border: 1px dashed var(--borda-2); border-radius: 12px; background: var(--superf-2); }
.compromissos-dia h3 { font-size: 14px; color: var(--texto-2); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; font-weight: 700; }
.compromissos-dia ul { list-style: none; display: flex; flex-wrap: wrap; gap: 10px; }
.compromissos-dia li { background: var(--superf); border: 1px solid var(--borda); border-radius: 20px; padding: 6px 14px; font-size: 13px; color: var(--texto-2); }

.dia-navegacao { display: flex; align-items: center; justify-content: space-between; margin-top: 30px; gap: 12px; }
.dia-navegacao a { background: var(--superf); border: 1px solid var(--borda); border-radius: 10px; padding: 11px 16px; font-size: 14px; box-shadow: var(--sombra-sm); }
.dia-navegacao a:hover { border-color: var(--brasa); }
.nav-mapa { color: var(--texto-2) !important; }

@media (max-width: 600px) {
    .hero-titulo, .login-logo { font-size: 42px; }
    .dia-cabecalho h1 { font-size: 32px; }
    .topbar { padding: 14px 16px; }
    .topbar-nav { gap: 14px; }
}
