/* ============================================================
   Área de Produtos MDR — estilo (tema escuro, acento roxo)
   ============================================================ */
:root{
    --bg:#0b0b12; --bg2:#12121c; --card:#171826; --card2:#1c1e2e;
    --linha:#262a3b; --linha2:#2f3446;
    --txt:#e8eaf2; --mut:#9aa3b8; --mut2:#6b7280;
    --acc:#7c3aed; --acc2:#a78bfa; --acc-soft:rgba(124,58,237,.14);
    --ok:#34d399; --ok-bg:rgba(52,211,153,.12);
    --err:#f87171; --err-bg:rgba(248,113,113,.12);
    --warn:#fbbf24; --warn-bg:rgba(251,191,36,.12);
    --drive:#1a73e8;
    --raio:14px; --raio-s:10px;
    --sombra:0 8px 30px rgba(0,0,0,.35);
    --font:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    font-family:var(--font); color:var(--txt); background:
        radial-gradient(1100px 600px at 90% -10%, rgba(124,58,237,.12), transparent 60%),
        radial-gradient(900px 500px at -10% 0%, rgba(59,130,246,.08), transparent 55%),
        var(--bg);
    min-height:100vh; -webkit-font-smoothing:antialiased; line-height:1.5;
}
a{color:var(--acc2); text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{color:#fff; line-height:1.25; margin:0 0 .3em}
h1{font-size:1.6rem; font-weight:800}
h2{font-size:1.15rem; font-weight:700}
small{font-size:.8rem}
.mut{color:var(--mut)}

/* ---- App bar (membro) ---- */
.appbar{position:sticky; top:0; z-index:40; background:rgba(11,11,18,.82); backdrop-filter:blur(12px); border-bottom:1px solid var(--linha)}
.appbar-in{max-width:1180px; margin:0 auto; padding:12px 18px; display:flex; align-items:center; justify-content:space-between; gap:12px}
.marca-logo{display:flex; align-items:center; gap:11px; color:#fff; text-decoration:none}
.marca-logo:hover{text-decoration:none}
.selo{width:40px; height:40px; border-radius:11px; display:grid; place-items:center;
    background:linear-gradient(135deg,var(--acc),#4f46e5); box-shadow:0 6px 18px rgba(124,58,237,.4)}
.selo svg{width:22px; height:22px; color:#fff}
.marca-logo .nome{display:flex; flex-direction:column; font-weight:800; font-size:1.02rem; line-height:1.1}
.marca-logo .nome small{font-weight:600; font-size:.62rem; letter-spacing:.14em; color:var(--acc2); margin-top:2px}
.appbar-acoes{display:flex; align-items:center; gap:10px}
.appbar-acoes .ola{color:var(--mut); font-size:.9rem; font-weight:600}
.appbar-acoes form{margin:0}

/* ---- Containers ---- */
.container{max-width:460px; margin:0 auto; padding:26px 18px 40px}
.wrap{max-width:1180px; margin:0 auto; padding:24px 18px 56px}
.rodape{text-align:center; color:var(--mut2); font-size:.8rem; padding:26px 16px 34px}

/* ---- Alertas ---- */
.alerta{padding:12px 15px; border-radius:var(--raio-s); margin:0 0 16px; font-size:.92rem; border:1px solid transparent}
.alerta-sucesso{background:var(--ok-bg); border-color:rgba(52,211,153,.35); color:#a7f3d0}
.alerta-erro{background:var(--err-bg); border-color:rgba(248,113,113,.35); color:#fecaca}
.alerta-aviso{background:var(--warn-bg); border-color:rgba(251,191,36,.35); color:#fde68a}
.alerta-info{background:var(--acc-soft); border-color:rgba(124,58,237,.35); color:var(--acc2)}

/* ---- Botões ---- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; cursor:pointer;
    background:linear-gradient(135deg,var(--acc),#5b21b6); color:#fff; border:0; border-radius:11px;
    padding:11px 18px; font-family:var(--font); font-weight:700; font-size:.94rem; text-decoration:none;
    transition:transform .05s ease, box-shadow .15s ease, filter .15s ease; box-shadow:0 6px 18px rgba(124,58,237,.28)}
.btn:hover{filter:brightness(1.08); text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn svg{width:18px; height:18px}
.btn-bloco{width:100%}
.btn-pequeno{padding:8px 12px; font-size:.85rem; border-radius:9px; box-shadow:none}
.btn-secundario{background:var(--card2); color:var(--txt); border:1px solid var(--linha2); box-shadow:none}
.btn-secundario:hover{background:#232538; filter:none}
.btn-drive{background:linear-gradient(135deg,#1a73e8,#1557b0); box-shadow:0 6px 18px rgba(26,115,232,.28)}
.btn-texto{background:none; border:0; color:var(--acc2); cursor:pointer; font-family:var(--font); font-weight:600; font-size:.88rem; padding:6px 0; display:inline-flex; align-items:center; gap:6px}
.btn-texto svg{width:15px; height:15px}
.btn-texto.perigo{color:var(--err)}
.mt{margin-top:14px}

/* ---- Cartões / forms ---- */
.cartao{background:linear-gradient(180deg,var(--card),var(--bg2)); border:1px solid var(--linha); border-radius:var(--raio); padding:22px; box-shadow:var(--sombra); margin-bottom:18px}
.cartao-cabecalho{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px}
.subtitulo{color:var(--mut); font-size:.92rem; margin:.2em 0 1em}
label{display:block; font-weight:600; font-size:.86rem; margin:14px 0 6px; color:#d5d9e6}
input,select,textarea{width:100%; padding:11px 13px; background:var(--bg); border:1px solid var(--linha2); border-radius:var(--raio-s);
    color:var(--txt); font-family:var(--font); font-size:.95rem; transition:border-color .15s ease, box-shadow .15s ease}
input:focus,select:focus,textarea:focus{outline:0; border-color:var(--acc); box-shadow:0 0 0 3px var(--acc-soft)}
textarea{resize:vertical}
.ajuda{display:block; color:var(--mut2); font-size:.78rem; margin-top:5px}
.sep{border:0; border-top:1px solid var(--linha); margin:18px 0}
.campo-senha{position:relative}
.campo-senha input{padding-right:44px}
.ver-senha{position:absolute; right:6px; top:50%; transform:translateY(-50%); background:none; border:0; color:var(--mut); cursor:pointer; padding:6px; border-radius:8px}
.ver-senha:hover{color:var(--txt); background:var(--card2)}
.ver-senha svg{width:19px; height:19px; display:block}

/* switches */
.switch{display:flex; align-items:center; gap:10px; margin:12px 0; font-weight:600; font-size:.9rem; color:#d5d9e6; cursor:pointer}
.switch input[type=checkbox]{width:auto; margin:0; width:18px; height:18px; accent-color:var(--acc)}
.switch input[type=hidden]{display:none}

/* ---- Tela de login (membro e admin) ---- */
.entrar-tela{min-height:calc(100vh - 160px); display:grid; place-items:center; padding:10px 0}
.entrar-cartao{max-width:400px; width:100%; text-align:center; margin:0}
.entrar-cartao form{text-align:left}
.entrar-cartao label{margin-top:12px}
.entrar-selo{width:58px; height:58px; margin:0 auto 12px; border-radius:16px; display:grid; place-items:center;
    background:linear-gradient(135deg,var(--acc),#4f46e5); box-shadow:0 10px 26px rgba(124,58,237,.45)}
.entrar-selo svg{width:28px; height:28px; color:#fff}
.entrar-ajuda{color:var(--mut2); font-size:.82rem; margin-top:16px}

/* ---- Hero do catálogo ---- */
.hero{margin-bottom:22px}
.hero h1{font-size:1.9rem; margin-bottom:.15em}
.hero p{color:var(--mut); max-width:640px; margin:0 0 14px}
.hero-cadastros{display:flex; flex-wrap:wrap; align-items:center; gap:9px; font-size:.86rem; color:var(--mut)}
.chip-link{display:inline-flex; align-items:center; gap:6px; padding:7px 13px; border-radius:999px; background:var(--card2);
    border:1px solid var(--linha2); color:var(--txt); font-weight:600; font-size:.83rem}
.chip-link:hover{border-color:var(--acc); text-decoration:none; color:var(--acc2)}

/* ---- Filtros e chips ---- */
.filtros{margin:0 0 16px}
.busca{position:relative; display:flex; align-items:center; max-width:520px}
.busca svg{position:absolute; left:13px; width:18px; height:18px; color:var(--mut2)}
.busca input{padding-left:40px}
.chips{display:flex; flex-wrap:wrap; gap:9px; margin:0 0 22px}
.chip{padding:8px 15px; border-radius:999px; background:var(--card); border:1px solid var(--linha2);
    color:var(--mut); font-weight:600; font-size:.85rem; cursor:pointer}
.chip:hover{color:var(--txt); text-decoration:none; border-color:var(--linha2)}
.chip.on{background:var(--acc-soft); border-color:var(--acc); color:var(--acc2)}

/* ---- Grade de produtos (membro) ---- */
.grade-produtos{display:grid; grid-template-columns:repeat(auto-fill,minmax(258px,1fr)); gap:18px}
.card-produto{background:linear-gradient(180deg,var(--card),var(--bg2)); border:1px solid var(--linha); border-radius:var(--raio);
    overflow:hidden; display:flex; flex-direction:column; transition:transform .12s ease, border-color .15s ease, box-shadow .15s ease}
.card-produto:hover{transform:translateY(-3px); border-color:var(--linha2); box-shadow:var(--sombra)}
.card-capa{position:relative; aspect-ratio:4/3; background:var(--bg2); overflow:hidden}
.card-capa img{width:100%; height:100%; object-fit:cover; display:block}
.capa-placeholder{width:100%; height:100%; display:grid; place-items:center;
    background:linear-gradient(135deg,#312e81,#4f46e5)}
.capa-placeholder[data-plat=cakto]{background:linear-gradient(135deg,#0f766e,#059669)}
.capa-placeholder[data-plat=atomo]{background:linear-gradient(135deg,#4338ca,#6366f1)}
.capa-placeholder[data-plat=hotmart]{background:linear-gradient(135deg,#b91c1c,#ef4444)}
.capa-placeholder[data-plat=kiwify]{background:linear-gradient(135deg,#5b21b6,#7c3aed)}
.capa-placeholder span{font-size:2.6rem; font-weight:800; color:rgba(255,255,255,.92)}
.tag-plat{position:absolute; top:10px; right:10px; padding:4px 10px; border-radius:999px; font-size:.7rem; font-weight:700;
    background:rgba(0,0,0,.55); color:#fff; backdrop-filter:blur(4px)}
.tag-destaque{position:absolute; top:10px; left:10px; display:inline-flex; align-items:center; gap:4px; padding:4px 9px; border-radius:999px;
    font-size:.68rem; font-weight:700; background:rgba(251,191,36,.92); color:#3b2a05}
.tag-destaque svg{width:12px; height:12px}
.card-corpo{padding:14px 15px 16px; display:flex; flex-direction:column; flex:1}
.card-cat{font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--acc2); margin-bottom:5px}
.card-corpo h3{font-size:1.02rem; margin-bottom:6px}
.card-desc{color:var(--mut); font-size:.84rem; margin:0 0 13px; flex:1}
.card-acoes{display:flex; flex-direction:column; gap:8px}
.card-acoes .btn{font-size:.86rem; padding:10px 12px}
.card-acoes .btn-copiar.copiado{background:linear-gradient(135deg,var(--ok),#059669)}
.sem-link{color:var(--mut2); font-size:.82rem; font-style:italic; padding:4px 0}

/* vazio */
.vazio{text-align:center; padding:60px 20px; color:var(--mut)}
.vazio svg{width:46px; height:46px; color:var(--linha2); margin-bottom:12px}

/* ============================================================
   ADMIN
   ============================================================ */
body.admin{background:var(--bg)}
.admin-topo{position:sticky; top:0; z-index:40; background:rgba(11,11,18,.9); backdrop-filter:blur(12px); border-bottom:1px solid var(--linha)}
.admin-topo .barra{max-width:1180px; margin:0 auto; padding:11px 18px; display:flex; align-items:center; gap:16px}
.admin-topo .marca-logo .nome{font-size:.98rem}
.admin-nav{display:flex; gap:4px; flex:1; flex-wrap:wrap}
.admin-nav .item{padding:8px 13px; border-radius:9px; color:var(--mut); font-weight:600; font-size:.9rem}
.admin-nav .item:hover{color:var(--txt); background:var(--card); text-decoration:none}
.admin-nav .item.ativo{color:#fff; background:var(--acc-soft); box-shadow:inset 0 0 0 1px rgba(124,58,237,.4)}
.admin-topo-acoes{display:flex; align-items:center; gap:8px}
.admin-topo-acoes form{margin:0}
.admin-wrap{max-width:1180px; margin:0 auto; padding:24px 18px 60px}

.pagina-cabecalho{display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin-bottom:20px; flex-wrap:wrap}
.pagina-cabecalho h1{margin-bottom:.1em}

/* stats */
.cards-stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:14px; margin-bottom:22px}
.stat{background:linear-gradient(180deg,var(--card),var(--bg2)); border:1px solid var(--linha); border-radius:var(--raio); padding:18px; position:relative}
.stat-icone{width:38px; height:38px; border-radius:10px; display:grid; place-items:center; background:var(--acc-soft); margin-bottom:10px}
.stat-icone svg{width:20px; height:20px; color:var(--acc2)}
.stat b{font-size:1.7rem; color:#fff; display:block; line-height:1}
.stat small{color:var(--mut2); font-size:.76rem}
.stat-rot{color:var(--mut); font-weight:600; font-size:.86rem; margin-top:2px}

/* tabelas */
.tabela-wrap{overflow-x:auto; margin:0 -4px}
.tabela{width:100%; border-collapse:collapse; font-size:.9rem}
.tabela th{text-align:left; color:var(--mut2); font-weight:600; font-size:.76rem; text-transform:uppercase; letter-spacing:.05em; padding:8px 10px; border-bottom:1px solid var(--linha)}
.tabela td{padding:12px 10px; border-bottom:1px solid var(--linha); vertical-align:middle}
.tabela tr:last-child td{border-bottom:0}
.tabela tr:hover td{background:rgba(255,255,255,.015)}
.linha-bloqueada td{opacity:.55}
.inline{display:inline; margin:0}
.col-acoes{white-space:nowrap; text-align:right}
.col-links{white-space:nowrap}
.icone-acao{display:inline-grid; place-items:center; width:34px; height:34px; border-radius:9px; background:var(--card2); border:1px solid var(--linha2); color:var(--mut); cursor:pointer; margin-left:4px; vertical-align:middle}
.icone-acao:hover{color:var(--txt); text-decoration:none; border-color:var(--acc)}
.icone-acao svg{width:17px; height:17px}
.icone-acao.perigo:hover{color:var(--err); border-color:var(--err)}
.dot{display:inline-grid; place-items:center; width:26px; height:26px; border-radius:7px; margin-right:3px}
.dot svg{width:15px; height:15px}
.dot.ok{background:var(--ok-bg); color:var(--ok)}
.dot.off{background:var(--card2); color:var(--linha2)}

/* pills / status */
.pill{display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:999px; font-size:.74rem; font-weight:700}
.pill-ok{background:var(--ok-bg); color:var(--ok)}
.pill-off{background:var(--err-bg); color:var(--err)}
.pill-star{background:var(--warn-bg); color:var(--warn)}
.pill-star svg{width:11px; height:11px}
.btn-status{border:0; cursor:pointer; padding:5px 12px; border-radius:999px; font-family:var(--font); font-weight:700; font-size:.76rem}
.btn-status.on{background:var(--ok-bg); color:var(--ok)}
.btn-status.off{background:var(--err-bg); color:var(--err)}

/* capa mini na tabela */
.mini-capa{width:46px; height:46px; border-radius:9px; object-fit:cover; display:block; background:var(--bg2)}
.mini-vazia{display:grid; place-items:center; color:var(--linha2); border:1px dashed var(--linha2)}
.mini-vazia svg{width:20px; height:20px}

/* form grid (2 colunas) */
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:start}
.form-grid .cartao{margin-bottom:0}

/* capa no form */
.capa-atual{margin-bottom:6px}
.capa-atual img{max-width:100%; width:200px; border-radius:var(--raio-s); border:1px solid var(--linha2)}
.capa-atual-vazia{width:200px; height:150px; border:1px dashed var(--linha2); border-radius:var(--raio-s); display:grid; place-items:center; color:var(--mut2); gap:6px}
.capa-atual-vazia svg{width:26px; height:26px}
.capa-atual-vazia span{font-size:.8rem}

/* edicao inline de categoria */
.inline-edit{display:flex; align-items:center; gap:6px; margin:0}
.inline-edit input[type=text]{min-width:150px}
.inp-ordem{width:70px}
.linha-campos{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.form-membro .btn{width:auto}

/* modal */
.modal{position:fixed; inset:0; z-index:80; background:rgba(3,4,10,.72); display:grid; place-items:center; padding:18px; backdrop-filter:blur(3px)}
.modal-caixa{background:linear-gradient(180deg,var(--card),var(--bg2)); border:1px solid var(--linha2); border-radius:var(--raio); padding:22px; max-width:440px; width:100%; box-shadow:var(--sombra)}
.modal-topo{display:flex; align-items:center; justify-content:space-between; margin-bottom:8px}
.modal-x{background:none; border:0; color:var(--mut); font-size:1.6rem; line-height:1; cursor:pointer; padding:0 6px}
.modal-x:hover{color:var(--txt)}

@media (max-width:820px){
    .form-grid{grid-template-columns:1fr}
    .linha-campos{grid-template-columns:1fr}
    .admin-nav{order:3; width:100%}
    .container{max-width:100%}
}
