:root { --vinho:#6E1B33; --vinho-escuro:#521022; --creme:#FAF1F3; --preto:#1c1c1c; --cinza:#6b6b6b; }
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Jost',system-ui,sans-serif; background:#f6f1ee; color:var(--preto); line-height:1.55; }
h1,h2,h3 { font-family:'Playfair Display',serif; }
a { color:var(--vinho-escuro); }

.admin-topo { background:var(--preto); color:#fff; display:flex; align-items:center; gap:24px; padding:14px 28px; flex-wrap:wrap; }
.admin-topo .marca { font-family:'Playfair Display',serif; font-size:22px; letter-spacing:1px; color:#fff; text-decoration:none; }
.admin-nav { display:flex; gap:10px; flex-wrap:wrap; padding:14px 24px; background:#fff;
  box-shadow:0 2px 10px rgba(0,0,0,.07); position:sticky; top:0; z-index:40; }
.admin-nav a { color:var(--preto); background:#f3e6ea; text-decoration:none; padding:12px 20px; border-radius:12px;
  font-size:16px; font-weight:600; letter-spacing:.2px; }
.admin-nav a:hover { background:var(--vinho-escuro); color:#fff; }
.admin-nav a.ativo { background:var(--vinho); color:#fff; box-shadow:0 4px 12px rgba(110,27,51,.35); }
.admin-sair { margin-left:auto; color:#ccc; text-decoration:none; font-size:15px; }
.admin-sair:hover { color:#fff; }

.admin-main { max-width:1100px; margin:28px auto; padding:0 20px; }
.admin-main h1 { font-size:28px; margin-bottom:18px; }

.cartoes { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:16px; margin-bottom:28px; }
.cartao { background:#fff; border-radius:14px; padding:20px; box-shadow:0 2px 12px rgba(0,0,0,.05); }
.cartao .num { font-size:30px; font-weight:600; color:var(--vinho-escuro); }
.cartao .rotulo { color:var(--cinza); font-size:14px; }

.painel { background:#fff; border-radius:14px; padding:22px; box-shadow:0 2px 12px rgba(0,0,0,.05); margin-bottom:24px; }
.painel h2 { font-size:20px; margin-bottom:14px; }

table.lista { width:100%; border-collapse:collapse; font-size:15px; }
table.lista th { text-align:left; color:var(--cinza); font-weight:500; padding:8px 10px; border-bottom:2px solid #eee; }
table.lista td { padding:10px; border-bottom:1px solid #f2ecea; vertical-align:middle; }
table.lista tr:hover td { background:#fdf8f6; }

.tag { display:inline-block; padding:3px 12px; border-radius:999px; font-size:13px; font-weight:500; }
.tag-pendente { background:#fff3cd; color:#8a6d1a; }
.tag-confirmado { background:#d8ecf8; color:#1c5c80; }
.tag-concluido { background:#d9f2e1; color:#1c6b35; }
.tag-cancelado { background:#fde1de; color:#a33; }

.btn { display:inline-block; padding:9px 20px; border-radius:10px; border:0; cursor:pointer; text-decoration:none;
  font-family:'Jost',sans-serif; font-size:15px; font-weight:500; }
.btn-p { background:var(--vinho); color:#fff; }
.btn-p:hover { background:var(--vinho-escuro); }
.btn-s { background:#eee; color:var(--preto); }
.btn-mini { padding:5px 12px; font-size:13px; border-radius:8px; }
.btn-perigo { background:#fde1de; color:#a33; }

.form-linha { margin-bottom:14px; }
.form-linha label { display:block; font-weight:500; margin-bottom:4px; font-size:14px; }
.form-linha input, .form-linha select, .form-linha textarea {
  width:100%; padding:10px 12px; border:1.5px solid #e3d7d1; border-radius:8px; font-family:'Jost',sans-serif; font-size:15px; }
.form-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:12px; }
.alerta { padding:12px 16px; border-radius:10px; margin-bottom:18px; }
.alerta-ok { background:#d9f2e1; color:#1c6b35; }
.alerta-erro { background:#fde1de; color:#a33; }

.login-box { max-width:380px; margin:9vh auto; background:#fff; padding:36px; border-radius:16px; box-shadow:0 8px 30px rgba(0,0,0,.08); }
.login-box h1 { text-align:center; font-size:22px; margin-bottom:6px; }
.login-box .sub { text-align:center; color:var(--cinza); margin-bottom:22px; font-size:14px; }

.barras { display:flex; align-items:flex-end; gap:10px; height:180px; padding-top:10px; }
.barras .col { flex:1; display:flex; flex-direction:column; justify-content:flex-end; align-items:center; gap:6px; height:100%; }
.barras .bar { width:100%; max-width:46px; background:var(--vinho); border-radius:6px 6px 0 0; min-height:2px; }
.barras .leg { font-size:12px; color:var(--cinza); }
.barras .val { font-size:12px; font-weight:600; }
