/* ============================================================
   FunSeekr · Estilos · paleta clara e quente
   ============================================================ */
:root{
  --cream:#FFF7EE;
  --cream-2:#FCEFD9;
  --card:#FFFFFF;
  --orange:#F7941D;       /* laranja vibrante (calendário/header) */
  --coral:#FF6A2B;        /* coral de destaque (links, contagem) */
  --coral-dark:#E0531A;
  --ink:#16223A;          /* azul-petróleo escuro p/ títulos */
  --ink-soft:#3A4661;
  --muted:#8A93A6;
  --border:#F0E6D6;
  --shadow:0 10px 30px rgba(22,34,58,.08);
  --radius:18px;
  --maxw:1080px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Plus Jakarta Sans','Segoe UI',system-ui,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- Cabeçalho ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,247,238,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar-inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;gap:16px;
  padding:14px 20px;
}
.menu-btn{
  width:46px;height:46px;border:1px solid var(--border);background:var(--card);
  border-radius:14px;display:grid;place-items:center;cursor:pointer;
  box-shadow:var(--shadow);transition:.15s;
}
.menu-btn:hover{border-color:var(--orange)}
.brand{
  flex:1;text-align:center;font-weight:800;font-size:24px;letter-spacing:-.02em;
  color:var(--ink);
}
.brand span{color:var(--coral)}
.search{
  display:flex;align-items:center;gap:8px;
  background:var(--card);border:1px solid var(--border);border-radius:999px;
  padding:9px 16px;box-shadow:var(--shadow);min-width:180px;
}
.search input{border:none;outline:none;background:none;font-size:15px;width:100%;color:var(--ink)}
.search svg{color:var(--coral);flex-shrink:0}
.lang-btn{display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--border);border-radius:999px;padding:9px 16px;box-shadow:var(--shadow);cursor:pointer;font-family:inherit;font-weight:700;font-size:14px;color:var(--ink)}
.lang-btn svg{color:var(--coral)}
.lang-btn:hover{border-color:var(--coral)}
/* Busca grande tipo Google na Home */
.bigsearch{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--border);border-radius:999px;padding:14px 22px;box-shadow:var(--shadow);margin:8px 0 16px;max-width:560px;margin-left:auto;margin-right:auto}
.bigsearch svg{color:var(--coral);flex-shrink:0}
.bigsearch input{border:none;outline:none;background:none;font-size:16px;width:100%;color:var(--ink);font-family:inherit}
.bigsearch:focus-within{border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,106,43,.12)}

/* ---------- Navegação em "pílulas" ---------- */
.navpills{
  max-width:var(--maxw);margin:0 auto;
  display:flex;gap:12px;padding:14px 20px;overflow-x:auto;
}
.navpills a{
  white-space:nowrap;background:var(--cream-2);
  padding:12px 22px;border-radius:14px;font-weight:600;font-size:15px;
  transition:.15s;
}
.navpills a:hover,.navpills a.active{background:var(--orange);color:#fff}

/* ---------- Container ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:8px 20px 60px}
.section-label{
  color:var(--coral);font-weight:800;font-size:13px;letter-spacing:.14em;
  text-transform:uppercase;margin:0 0 10px;
}

/* ---------- Carrossel / Banner próximos eventos ---------- */
.carousel{position:relative;margin:18px 0 28px;padding:0 30px}
.carousel-track{
  display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:8px;scrollbar-width:thin;scroll-behavior:smooth;
}
.cbtn{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;
  background:#fff;color:var(--coral);font-size:26px;font-weight:700;line-height:1;
  box-shadow:0 6px 18px rgba(22,34,58,.18);display:grid;place-items:center;transition:.15s;
}
.cbtn:hover{background:var(--coral);color:#fff}
.cbtn-prev{left:-4px}
.cbtn-next{right:-4px}
@media(max-width:560px){.carousel{padding:0}.cbtn{display:none}}

/* ---------- Lista compacta: 14h-22h - Nome  ·  ver evento ---------- */
.list-row{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--card);border:1px solid var(--border);border-bottom:none;padding:16px 18px;
}
.list-row:first-of-type{border-radius:12px 12px 0 0}
.list-row:last-of-type{border-radius:0 0 12px 12px;border-bottom:1px solid var(--border)}
.list-line{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;min-width:0}
.list-line .lt{color:var(--coral);font-weight:800;font-size:17px;white-space:nowrap;min-width:104px;display:inline-block;font-variant-numeric:tabular-nums}
.list-line .ld{color:var(--muted)}
.list-line .ln{font-weight:700;font-size:17px;color:var(--ink)}
.list-line .ln:hover{color:var(--coral)}
.list-line .lloc{color:var(--muted);font-size:14px;font-weight:500}
.ver-evento{
  white-space:nowrap;color:var(--coral);font-weight:700;font-size:14px;
  border:1.5px solid var(--coral);border-radius:999px;padding:7px 16px;transition:.15s;flex-shrink:0;
}
.ver-evento:hover{background:var(--coral);color:#fff}
@media(max-width:520px){
  .list-line .lt,.list-line .ln{font-size:15px}
  .list-line .lt{min-width:92px}
  .ver-evento{padding:6px 12px;font-size:13px}
}

.carousel-track::-webkit-scrollbar{height:6px}
.carousel-track::-webkit-scrollbar-thumb{background:var(--cream-2);border-radius:3px}
.cslide{
  scroll-snap-align:start;flex:0 0 86%;max-width:380px;
  background:linear-gradient(135deg,var(--coral),var(--orange));
  color:#fff;border-radius:var(--radius);padding:22px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);
}
.cslide .badge{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.9}
.cslide h3{font-size:24px;margin:8px 0 6px;line-height:1.15;font-weight:800}
.cslide .meta{font-size:14px;opacity:.95;display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.cslide .meta span{display:inline-flex;align-items:center;gap:5px}
.cslide-alt{background:#fff;border:1px solid var(--border);color:var(--ink)}
.cslide-alt .badge{color:var(--coral);opacity:1}
.cslide-alt .meta{color:var(--muted);opacity:1}
/* Enquetes (resenha) */
.poll{scroll-snap-align:start;flex:0 0 86%;max-width:420px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.poll-q{font-weight:800;font-size:19px;margin-bottom:14px;line-height:1.25}
.poll-opts{display:flex;flex-direction:column;gap:10px}
.poll-opt{text-align:left;padding:13px 16px;border:1.5px solid var(--border);border-radius:12px;background:var(--cream);font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s;color:var(--ink)}
.poll-opt:hover{border-color:var(--coral);background:#fff8f3}
.poll-result{display:flex;flex-direction:column;gap:12px}
.bar-row{display:flex;flex-direction:column;gap:5px}
.bar-label{font-size:14px;font-weight:600}
.bar-label b{color:var(--coral)}
.bar{height:10px;background:var(--cream-2);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--coral));border-radius:6px;transition:width .5s ease}
.poll-total{font-size:13px;color:var(--muted);margin-top:4px}

/* ---------- Banner CTA grande ---------- */
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;margin:20px 0 30px}
.hero-card{
  background:var(--card);border:1px solid var(--border);border-radius:22px;
  padding:30px;box-shadow:var(--shadow);
}
.hero-card h1{font-size:40px;line-height:1.05;font-weight:800;letter-spacing:-.03em;margin:8px 0 16px}
.hero-card h1 em{color:var(--coral);font-style:normal}
.hero-card p{color:var(--ink-soft);font-size:16px;margin:0 0 18px}
.next-pill{
  background:var(--cream-2);border-radius:14px;padding:16px;margin-top:10px;
}
.next-pill .tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.next-pill .tags span{background:#fff;border-radius:999px;padding:5px 12px;font-size:13px;font-weight:600}
.next-pill h4{margin:4px 0 6px;font-size:20px;font-weight:800}
.next-pill .count{color:var(--coral);font-weight:700;font-size:14px}
.cta-card{
  background:linear-gradient(150deg,var(--orange),var(--coral));
  color:#fff;border-radius:22px;padding:30px;display:flex;flex-direction:column;
  box-shadow:var(--shadow);
}
.cta-card .lbl{font-size:13px;font-weight:800;letter-spacing:.14em;opacity:.9}
.cta-card h2{font-size:30px;font-weight:800;line-height:1.1;margin:10px 0}
.cta-card p{opacity:.95;font-size:15px;margin:0 0 auto}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:14px;border:none;cursor:pointer;
  font-weight:700;font-size:16px;font-family:inherit;transition:.15s;text-align:center;
}
.btn-primary{background:var(--coral);color:#fff}
.btn-primary:hover{background:var(--coral-dark)}
.btn-white{background:#fff;color:var(--coral)}
.btn-white:hover{background:#fff8f3}
.btn-outline{background:transparent;color:var(--coral);border:2px solid var(--coral)}
.btn-outline:hover{background:var(--coral);color:#fff}
.btn-block{width:100%}
.btn-lg{padding:18px 28px;font-size:18px;border-radius:16px}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1db855}
.btn-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366);color:#fff}

/* ---------- Calendário: alternância mês/lista ---------- */
.cal-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin:10px 0 18px;flex-wrap:wrap;
}
.cal-nav{display:flex;gap:8px}
.cal-nav a,.cal-toggle a{
  background:var(--orange);color:#fff;border-radius:12px;padding:10px 16px;
  font-weight:700;display:inline-flex;align-items:center;gap:6px;
}
.cal-nav a.ghost{background:var(--cream-2);color:var(--ink)}
.cal-title{font-size:22px;font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.cal-toggle{display:flex;gap:8px}
.cal-toggle a.off{background:#fff;color:var(--orange);border:1.5px solid var(--orange)}

/* ---- Visão MÊS ---- */
.cal-grid{
  background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow);
}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:var(--ink)}
.cal-head div{color:#fff;font-weight:700;text-align:center;padding:14px 4px;font-size:13px;letter-spacing:.08em}
.cal-body{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-cell{min-height:120px;border-right:1px solid var(--border);border-top:1px solid var(--border);padding:8px;position:relative}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell .num{position:absolute;top:6px;right:10px;font-weight:700;color:var(--ink)}
.cal-cell.out .num{color:#cfc6b6}
.cal-cell.today{background:#FFF3E0}
.cal-ev{
  display:block;background:var(--orange);color:#fff;border-radius:8px;
  padding:5px 9px;font-size:12px;font-weight:600;margin:26px 0 5px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cal-ev:hover{background:var(--coral)}
.cal-more{font-size:12px;color:var(--muted);font-weight:600;padding-left:2px}

/* ---- Visão LISTA ---- */
.list-day{background:var(--ink);color:#fff;border-radius:12px;padding:14px 18px;
  display:flex;justify-content:space-between;font-weight:800;margin:18px 0 4px;font-size:15px}

/* ---------- Cards de lugares ---------- */
.places{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}

/* ---------- Listagem alfabética (lista telefônica) ---------- */
.alpha-index{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 22px;position:sticky;top:74px;background:rgba(255,247,238,.95);padding:10px 0;z-index:5}
.alpha-index a{width:34px;height:34px;display:grid;place-items:center;border-radius:9px;background:var(--cream-2);color:var(--coral);font-weight:800;font-size:14px;transition:.15s}
.alpha-index a:hover{background:var(--coral);color:#fff}
.alpha-index span.off{width:34px;height:34px;display:grid;place-items:center;color:#d8cdb8;font-weight:700;font-size:14px}
.alpha-block{margin-bottom:18px;scroll-margin-top:130px}
.alpha-letter{font-family:inherit;font-size:24px;font-weight:800;color:#fff;background:var(--ink);width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:8px}
.alpha-list{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.alpha-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}
.alpha-item:last-child{border-bottom:none}
.alpha-item:hover{background:#fffaf3}
.ai-main{min-width:0}
.ai-name{font-weight:700;font-size:17px;display:block;cursor:pointer;transition:color .15s}
a.ai-name:hover{color:var(--coral)!important}
.ai-meta{color:var(--muted);font-size:13px}
.ai-ig{color:var(--coral);font-weight:700;font-size:14px;white-space:nowrap;flex-shrink:0}
.ai-ig:hover{text-decoration:underline}
.ai-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.ai-wa{display:inline-flex;align-items:center;gap:5px;background:#25D366;color:#fff;font-weight:700;font-size:13px;padding:7px 12px;border-radius:999px;text-decoration:none;white-space:nowrap}
.ai-wa:hover{filter:brightness(.95)}
.ai-wa svg{flex-shrink:0}
.place{background:var(--cream-2);border-radius:16px;padding:18px}
.place .pn{font-weight:800;font-size:18px;display:flex;align-items:center;gap:8px}
.place .pn svg{color:var(--coral)}
.place .pm{color:var(--ink-soft);font-size:14px;margin-top:6px}

/* ---------- Página de detalhe ---------- */
.detail{background:var(--card);border:1px solid var(--border);border-radius:22px;padding:30px;box-shadow:var(--shadow)}
.detail .kick{color:var(--coral);font-weight:800;letter-spacing:.1em;text-transform:uppercase;font-size:13px}
.detail h1{font-size:34px;font-weight:800;letter-spacing:-.02em;margin:8px 0 18px;line-height:1.1}
.detail-desc{font-size:17px;color:var(--ink);margin:-6px 0 20px;line-height:1.55;font-weight:500;background:var(--cream);border-left:3px solid var(--coral);padding:12px 16px;border-radius:8px}
.detail-meta{display:flex;flex-wrap:wrap;gap:14px 28px;margin-bottom:22px}
.detail-meta .it{display:flex;align-items:center;gap:8px;font-size:16px}
.detail-meta .it svg{color:var(--coral)}
.count{background:var(--cream);border-radius:16px;padding:22px;text-align:center;margin:22px 0 0;border:1px solid var(--border)}
.count .lbl{color:var(--muted);font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:12px}
.count-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
.count-box{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 4px}
.count-num{font-size:30px;font-weight:800;color:var(--coral);line-height:1}
.count-unit{font-size:11px;text-transform:uppercase;color:var(--muted);margin-top:4px}
.detail-actions{display:flex;flex-wrap:wrap;gap:12px}

/* ---------- Formulários ---------- */
.form-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:28px;box-shadow:var(--shadow);max-width:560px;margin:0 auto}
.form-card h2{margin:0 0 6px;font-size:26px;font-weight:800}
.form-card .sub{color:var(--ink-soft);margin:0 0 22px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:700;font-size:14px;margin-bottom:6px;color:var(--ink-soft)}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1px solid var(--border);border-radius:12px;
  background:var(--cream);font-size:15px;font-family:inherit;color:var(--ink);outline:none;transition:.15s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,106,43,.12)}
.field textarea{resize:vertical;min-height:120px;font-family:inherit;line-height:1.5}
.form-sec{font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--coral);margin:22px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.form-sec:first-of-type{margin-top:0}
/* Gate de newsletter */
.news-gate{position:fixed;inset:0;background:rgba(22,34,58,.55);backdrop-filter:blur(4px);z-index:200;display:grid;place-items:center;padding:20px}
.news-box{background:var(--cream);border-radius:22px;padding:32px 28px;max-width:420px;width:100%;text-align:center;box-shadow:0 24px 60px rgba(22,34,58,.3)}
.news-logo{font-weight:800;font-size:26px;letter-spacing:-.02em;margin-bottom:10px}
.news-box h3{font-size:22px;font-weight:800;margin:0 0 8px}
.news-box p{color:var(--ink-soft);margin:0 0 18px;font-size:15px}
.news-box input{width:100%;box-sizing:border-box;padding:13px 15px;border:1px solid var(--border);border-radius:12px;background:#fff;font-size:15px;margin-bottom:12px;outline:none}
.news-box input:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,106,43,.12)}
.news-box small{display:block;color:var(--muted);font-size:12px;margin-top:12px}
.news-box{position:relative}
.news-x{position:absolute;top:14px;right:16px;background:none;border:none;font-size:28px;line-height:1;color:var(--muted);cursor:pointer;padding:0;width:32px;height:32px}
.news-x:hover{color:var(--ink)}
.news-skip{background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer;margin-top:12px;text-decoration:underline;font-family:inherit;width:100%}
.news-skip:hover{color:var(--ink)}
/* Bloco de newsletter no rodapé */
.footer-news{max-width:520px;margin:0 auto;padding:30px 22px 6px;text-align:center}
.footer-news h3{font-size:20px;font-weight:800;margin:0 0 6px;color:var(--ink)}
.footer-news p{color:var(--muted);margin:0 0 16px;font-size:15px}
.fn-form{display:flex;gap:10px;max-width:440px;margin:0 auto}
.fn-form input{flex:1;padding:13px 16px;border:1px solid var(--border);border-radius:12px;background:var(--card);font-size:15px;outline:none}
.fn-form input:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,106,43,.12)}
.fn-form .btn{white-space:nowrap}
.fn-msg{margin-top:12px;font-size:14px;font-weight:600}
.fn-ok{color:#1a7f37}
.fn-err{color:#b3261e}
@media(max-width:520px){.fn-form{flex-direction:column}}
.news-err{background:#FDEBEC;color:#b3261e;padding:10px;border-radius:10px;font-size:14px;margin-bottom:12px;font-weight:600}
/* Página de confirmação de pagamento */
.confirm-card{max-width:480px;margin:20px auto;background:var(--card);border:1px solid var(--border);border-radius:22px;padding:38px 30px;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.confirm-emoji{font-size:64px;line-height:1;animation:pop .6s ease;margin-bottom:8px}
@keyframes pop{0%{transform:scale(0) rotate(-20deg);opacity:0}60%{transform:scale(1.25) rotate(8deg)}100%{transform:scale(1) rotate(0);opacity:1}}
.confirm-card h1{font-size:26px;font-weight:800;margin:6px 0 12px;color:var(--ink)}
.confirm-lead{font-size:17px;color:var(--ink);margin:0 0 10px;line-height:1.5}
.confirm-sub{font-size:15px;color:var(--ink-soft);margin:0 0 22px;line-height:1.55}
.confirm-help{margin-top:22px;padding-top:18px;border-top:1px solid var(--border);font-size:14px;color:var(--muted);line-height:1.5}
.confirm-help a{color:var(--coral);font-weight:700;text-decoration:none}
.confetti{position:absolute;inset:0 0 auto 0;height:0;pointer-events:none}
.confetti span{position:absolute;top:-10px;font-size:22px;animation:fall 2.6s linear infinite}
.confetti span:nth-child(1){left:10%;animation-delay:0s}
.confetti span:nth-child(2){left:30%;animation-delay:.5s}
.confetti span:nth-child(3){left:50%;animation-delay:1s}
.confetti span:nth-child(4){left:70%;animation-delay:.3s}
.confetti span:nth-child(5){left:88%;animation-delay:.8s}
@keyframes fall{0%{transform:translateY(0) rotate(0);opacity:1}100%{transform:translateY(380px) rotate(360deg);opacity:0}}
.row2{display:flex;gap:12px}
.row2 .field{flex:1}
.price-note{background:var(--cream-2);border-radius:14px;padding:16px;text-align:center;margin:6px 0 18px;font-weight:700}
.price-note b{color:var(--coral);font-size:22px}
.mailing-note{background:#FFF3E0;border:1px solid #F7D9A8;border-radius:12px;padding:13px 16px;margin:0 0 18px;font-size:14px;color:var(--ink-soft);line-height:1.5}
.mailing-note b{color:var(--coral)}

/* Planos (lugares) */
.plans{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.plan{border:2px solid var(--border);border-radius:16px;padding:20px;text-align:center;cursor:pointer;transition:.15s;background:#fff}
.plan:hover,.plan.sel{border-color:var(--coral);background:#fff8f3}
.plan .pp{font-size:13px;font-weight:700;text-transform:uppercase;color:var(--muted);letter-spacing:.08em}
.plan .pv{font-size:30px;font-weight:800;color:var(--coral);margin:6px 0}
.plan .pd{font-size:13px;color:var(--ink-soft)}

/* ---------- Drawer (menu lateral) ---------- */
.overlay{position:fixed;inset:0;background:rgba(22,34,58,.4);z-index:60;display:none}
.overlay.open{display:block}
.drawer{
  position:fixed;top:0;left:0;bottom:0;width:84%;max-width:330px;background:var(--cream);
  z-index:70;transform:translateX(-100%);transition:transform .25s cubic-bezier(.16,1,.3,1);
  padding:20px;box-shadow:8px 0 40px rgba(22,34,58,.2);display:flex;flex-direction:column;overflow-y:auto;
}
.drawer.open{transform:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.drawer-head b{font-size:18px}
.drawer a.cat{display:flex;align-items:center;gap:12px;padding:14px 12px;border-radius:12px;font-weight:600;font-size:16px;transition:.15s}
.drawer-group{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);margin:16px 12px 4px}
.drawer a.cat.slim{padding:11px 12px;font-size:15px;font-weight:600;color:var(--ink-soft)}
.drawer a.cat:hover{background:var(--cream-2)}
.drawer a.cat .ic{width:36px;height:36px;border-radius:10px;background:#FFE7D5;display:grid;place-items:center;color:var(--coral)}
.drawer .foot{margin-top:auto;padding-top:16px}

/* ---------- Rodapé ---------- */
.footer{border-top:1px solid var(--border);padding:30px 20px 50px;text-align:center;color:var(--muted)}
.footer .fb{font-weight:800;font-size:20px;color:var(--ink)}
.footer .fb span{color:var(--coral)}
.footer .socials{display:flex;gap:10px;justify-content:center;margin:14px 0}
.footer .socials a{width:42px;height:42px;border-radius:12px;background:var(--cream-2);display:grid;place-items:center;color:var(--coral);transition:.15s}
.footer .socials a:hover{background:var(--coral);color:#fff}

/* ---------- Mensagens ---------- */
.alert{padding:14px 18px;border-radius:12px;margin-bottom:18px;font-weight:600}
.alert-ok{background:#E6F7EC;color:#1c7a40}
.alert-err{background:#FDEBEC;color:#b3261e}
.empty{padding:50px 20px;text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:16px}

/* ---------- Admin ---------- */
.admin-shell{max-width:var(--maxw);margin:0 auto;padding:20px}
.admin-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.admin-tabs{display:flex;gap:10px;margin-bottom:20px}
.admin-tabs a{padding:10px 18px;border-radius:12px;background:var(--cream-2);font-weight:700}
.admin-tabs a.active{background:var(--orange);color:#fff}
.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.tbl th{background:var(--ink);color:#fff;text-align:left;padding:13px 14px;font-size:13px;letter-spacing:.04em}
.tbl td{padding:12px 14px;border-top:1px solid var(--border);font-size:14px}
.tbl tr:hover td{background:#fffaf3}
.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}
.tag-pub{background:#E6F7EC;color:#1c7a40}
.tag-pend{background:#FFF3E0;color:#b5760a}
.act{display:inline-flex;gap:6px}
.act a{padding:6px 10px;border-radius:8px;font-size:13px;font-weight:700}
.act .ed{background:var(--cream-2)}
.act .del{background:#FDEBEC;color:#b3261e}
.login-box{max-width:380px;margin:8vh auto;background:#fff;border:1px solid var(--border);border-radius:20px;padding:32px;box-shadow:var(--shadow)}
.destaque-toggle{display:flex;align-items:center;gap:10px;background:#FFF3E0;border:1px solid #F7D9A8;border-radius:12px;padding:14px 16px;margin-bottom:16px;cursor:pointer;font-size:15px}
.destaque-toggle input{width:20px;height:20px;cursor:pointer}
/* Dashboard */
.dash-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.dash-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.dash-card.hl{background:linear-gradient(150deg,var(--orange),var(--coral));color:#fff;border:none}
.dc-num{font-size:28px;font-weight:800;letter-spacing:-.02em}
.dc-lbl{font-size:13px;opacity:.85;margin-top:4px}
.dash-charts{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.chart-box{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.chart-box h3{margin:0 0 14px;font-size:17px}
.chart-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.legend{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:15px}
.legend .dot{display:inline-block;width:14px;height:14px;border-radius:4px;margin-right:8px;vertical-align:middle}
@media(max-width:760px){.dash-cards{grid-template-columns:1fr 1fr}.dash-charts{grid-template-columns:1fr}}
.login-box h1{text-align:center;font-size:26px;margin:0 0 6px}
.login-box .sub{text-align:center;color:var(--muted);margin:0 0 22px}

/* ---------- Responsivo ---------- */
@media(max-width:820px){
  .hero-grid{grid-template-columns:1fr}
  .hero-card h1{font-size:32px}
  .cal-cell{min-height:80px}
  .cal-ev{font-size:10px;margin-top:24px}
}
@media(max-width:520px){
  .row2{flex-direction:column}
  .plans{grid-template-columns:1fr}
  .search{min-width:0;width:46px;padding:9px}
  .search input{display:none}
  .brand{font-size:20px}
  .count-num{font-size:24px}
  .cal-head div{font-size:10px;padding:10px 2px}
  .cal-cell{min-height:64px;padding:4px}
  .cal-cell .num{font-size:13px;top:3px;right:6px}
}

/* Meta de receita no dashboard */
.meta-box{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;margin:20px 0;box-shadow:var(--shadow)}
.meta-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.meta-title{font-weight:800;font-size:18px;color:var(--ink)}
.meta-sub{color:var(--muted);font-size:14px;margin-top:2px}
.meta-sub b{color:var(--coral)}
.meta-bar{background:var(--cream-2);height:14px;border-radius:10px;overflow:hidden}
.meta-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--coral));border-radius:10px;transition:width .5s ease}
