.auth-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:420px;position:relative;overflow:hidden}
.auth-card::before{content:'';position:absolute;top:-80px;right:-80px;width:260px;height:260px;background:radial-gradient(circle,rgba(0,229,160,.07) 0%,transparent 70%);pointer-events:none}
.auth-tag{font-family:var(--mono);font-size:10px;color:var(--teal);letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.auth-tag::before{content:'';display:inline-block;width:16px;height:1px;background:var(--teal)}
.auth-title{font-family:var(--mono);font-size:22px;font-weight:700;line-height:1.15;margin-bottom:6px}
.auth-title span{color:var(--teal)}
.auth-sub{font-size:13px;color:var(--muted);margin-bottom:28px}
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;font-weight:500;color:var(--muted);margin-bottom:5px;letter-spacing:.04em;text-transform:uppercase;font-family:var(--mono)}
.field input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:11px 14px;font-family:var(--sans);font-size:14px;color:var(--text);transition:border-color .15s;outline:none}
.field input:focus{border-color:rgba(0,229,160,.4)}
.field input::placeholder{color:var(--muted)}
.btn-primary{width:100%;background:var(--teal);border:none;border-radius:8px;padding:13px;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.06em;color:#000;cursor:pointer;transition:opacity .15s;margin-top:6px}
.btn-primary:hover{opacity:.88}
.btn-primary:disabled{opacity:.4;cursor:not-allowed}
.auth-msg{border-radius:7px;padding:10px 14px;font-size:12px;margin-top:10px;display:none}
.auth-msg.show{display:block}
.auth-error{background:rgba(255,95,95,.08);border:1px solid rgba(255,95,95,.2);color:var(--red)}
.auth-success{background:rgba(0,229,160,.08);border:1px solid rgba(0,229,160,.2);color:var(--teal)}
.auth-warn{background:rgba(255,184,48,.08);border:1px solid rgba(255,184,48,.2);color:var(--amber)}
.spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(0,0,0,.3);border-top-color:#000;border-radius:50%;animation:spin .7s linear infinite;margin-right:5px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-visitor{width:100%;background:transparent;border:1px solid var(--border);border-radius:8px;padding:11px;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--muted);cursor:pointer;transition:all .15s;margin-top:8px}
.btn-visitor:hover{border-color:var(--teal);color:var(--teal)}
.auth-toggle{text-align:center;margin-top:14px;font-size:12px;color:var(--muted)}
.auth-toggle a{color:var(--teal);text-decoration:none;opacity:.7;font-family:var(--mono);font-size:10px;letter-spacing:.04em}
.auth-toggle a:hover{opacity:1}
.btn-visitor.btn-portfolio{background:var(--teal);color:#000;border-color:var(--teal);font-size:12px;font-weight:700;margin-top:6px}
.btn-visitor.btn-portfolio:hover{opacity:.88;color:#000}

/* ── Nova landing — layout full-page ──────────────────────── */
@keyframes ldot{0%,100%{opacity:1}50%{opacity:.3}}

.lp-topbar{display:flex;justify-content:space-between;align-items:center;padding:20px 48px;background:var(--bg)}
.lp-logo{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--teal);letter-spacing:.1em;cursor:default;user-select:none}
.lp-topbar-right{display:flex;align-items:center;gap:16px}
.lp-loc{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.08em}
.nav-status{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;color:#00e5a0;letter-spacing:.06em}
.nav-dot{width:6px;height:6px;background:#00e5a0;border-radius:50%;animation:ldot 2s infinite}

.lp-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;max-width:1100px;margin:0 auto;padding:32px 48px 80px;align-items:start}
@media(max-width:800px){.lp-grid{grid-template-columns:1fr;gap:36px;padding:24px 24px 60px}}

.lp-col-left{position:sticky;top:20px}
.lp-name{font-family:var(--mono);font-size:54px;font-weight:700;line-height:1.0;color:var(--text);margin-bottom:14px}
.lp-role-line{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--muted);margin-bottom:8px}
.lp-current-role{font-family:var(--mono);font-size:12px;color:#64748b;margin-bottom:20px;line-height:1.4}
.lp-bio{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:20px}
.proof-row{display:flex;gap:20px;margin-bottom:1.6rem;padding:.8rem 1rem;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:8px;flex-wrap:wrap}
.proof-item{display:flex;flex-direction:column}
.proof-value{font-family:var(--mono);font-size:16px;color:#fff;font-weight:700}
.proof-label{font-size:11px;color:#475569}
.lp-skill-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.lp-skill-tags span{font-family:var(--mono);font-size:10px;font-weight:600;padding:5px 12px;border-radius:20px;background:rgba(255,255,255,.04);border:1px solid var(--border2);color:var(--text)}
.lp-cta-row{display:flex;gap:10px;flex-wrap:wrap}
.lp-cta-row .lp-cta{flex:0 0 130px;max-width:130px;box-sizing:border-box;font-family:var(--sans);font-size:14px;font-weight:500;padding:11px 0;text-align:center;border-radius:8px;text-decoration:none;transition:background .15s,border-color .15s;letter-spacing:0}
.lp-cta-solid{background:var(--teal);color:#000;border:1px solid var(--teal)}
.lp-cta-solid:hover{opacity:.88}
.lp-cta-outline{color:var(--text);background:transparent;border:1px solid rgba(255,255,255,.15)}
.lp-cta-outline:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.28)}

.btn-contato{display:inline-block;width:130px;padding:11px 0;text-align:center;border-radius:8px;font-family:var(--sans);font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;box-sizing:border-box;transition:opacity .15s,background .15s}
.btn-contato-solid{background:#00e5a0;color:#0a0e13;border:1px solid #00e5a0}
.btn-contato-solid:hover{opacity:.85}
.btn-contato-ghost{background:transparent;color:#00e5a0;border:1px solid rgba(0,229,160,.4)}
.btn-contato-ghost:hover{background:rgba(0,229,160,.07);border-color:rgba(0,229,160,.7)}

.lp-col-right{display:flex;flex-direction:column;gap:20px}
.lp-section-lbl{font-family:var(--mono);font-size:9px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}

.lp-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.lp-stat-box{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center}
.lp-stat-n{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}
.lp-stat-l{font-size:10px;color:var(--muted)}

.lp-proj-list{display:flex;flex-direction:column;gap:10px}
.lp-proj-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px;transition:border-color .2s}
.lp-proj-card:hover{border-color:rgba(255,255,255,.15)}
.lp-proj-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.lp-proj-name{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text)}
.lp-proj-arrow{font-size:14px;color:var(--muted)}
.lp-proj-desc{font-size:12px;color:var(--muted);line-height:1.65;margin-bottom:12px}
.lp-proj-tags{display:flex;flex-wrap:wrap;gap:6px}
.lp-proj-tags span{font-family:var(--mono);font-size:9px;font-weight:600;padding:3px 8px;border-radius:12px;border:1px solid var(--border2);color:var(--muted)}

/* Career card */
.lp-career-card{background:var(--bg2);border:1px solid rgba(0,229,160,.18);border-radius:12px;overflow:hidden;position:relative}
.lp-career-head{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--teal);padding:12px 16px;border-bottom:1px solid var(--border)}
.lp-career-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:ldot 2s infinite;flex-shrink:0}
.lp-career-updated{font-family:var(--mono);font-size:9px;color:#475569;letter-spacing:.04em}
.lp-career-body{padding:1rem 1rem;display:flex;flex-direction:column;gap:10px}
.lp-career-phases{display:flex;flex-direction:column;gap:5px}
.lp-phase-row{display:flex;align-items:center;gap:8px}
.lp-phase-lbl{font-family:var(--mono);font-size:10px;color:var(--muted);min-width:44px}
.lp-phase-pct{font-family:var(--mono);font-size:10px;color:var(--teal);min-width:32px;text-align:right}
.lp-cert-bar{flex:1;background:rgba(255,255,255,.06);border-radius:3px;height:4px;overflow:hidden}
.lp-cert-fill{height:100%;background:var(--teal);border-radius:3px}
.lp-streak{display:flex;gap:3px;flex-wrap:wrap}
.lp-streak-sq{width:13px;height:13px;border-radius:3px;background:rgba(255,255,255,.05);border:1px solid var(--border)}
.lp-streak-on{background:var(--teal);border-color:var(--teal)}
.lp-blur{filter:blur(3px);pointer-events:none;user-select:none}
/* Teaser grid */
.teaser-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.teaser-block{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:.7rem}
.teaser-title{font-family:var(--mono);font-size:9px;color:#475569;letter-spacing:1px;margin-bottom:.5rem;text-transform:uppercase}
/* Locked preview */
.locked-preview{position:relative}
.locked-rows{filter:blur(4px);pointer-events:none;user-select:none;display:flex;flex-direction:column;gap:6px}
.lock-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.lock-badge{background:rgba(10,14,19,.85);border:1px solid rgba(0,229,160,.2);border-radius:20px;padding:4px 12px;font-family:var(--mono);font-size:10px;color:#00e5a0}
/* CTA */
.cta-section{display:flex;flex-direction:column;gap:6px}
.cta-hint{font-size:11px;color:#475569;text-align:center;line-height:1.5}
.cta-hint span{color:#00e5a0}
.unlock-btn{width:100%;padding:11px 0;background:#00e5a0;color:#0a0e13;border:none;border-radius:8px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}
.unlock-btn:hover{opacity:.85}

/* Modal de login admin */
.lp-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:1000}
.lp-modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:36px;width:100%;max-width:380px}
.lp-modal-title{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text);margin-bottom:20px;letter-spacing:.06em;text-transform:uppercase}
