/* ============================================================
   Sistema Pastoral — "Luz que reúne"
   índigo-noite + ouro de vela · Bricolage Grotesque + Inter
   Mobile-first.
============================================================ */
:root{
  --ink:#1E1B33;          /* índigo-noite (céu/Caeli) */
  --ink-2:#26223f;
  --ink-3:#322c52;
  --line:#3a3458;
  --gold:#DDA24A;         /* ouro de vela (acento único) */
  --gold-deep:#C8862F;
  --wine:#6E3257;         /* roxo litúrgico (secundário) */
  --linen:#F6F1E8;        /* papel */
  --linen-2:#FBF8F2;
  --cloud:#ffffff;
  --text:#211F33;
  --muted:#6c6880;
  --soft:#9a96ad;
  --ok:#3f9b6a;
  --danger:#c4453f;
  --accent:var(--gold);
  --radius:16px;
  --radius-sm:11px;
  --shadow:0 8px 30px rgba(30,27,51,.10);
  --shadow-sm:0 2px 10px rgba(30,27,51,.07);
  --tab-h:64px;
  font-synthesis-weight:none;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--linen);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
h1,h2,h3{font-family:'Bricolage Grotesque',Inter,sans-serif;font-weight:700;letter-spacing:-.01em;margin:0}
a{color:inherit}
img{max-width:100%;display:block}
code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em;background:rgba(0,0,0,.05);padding:1px 6px;border-radius:6px;letter-spacing:.04em}
::selection{background:var(--gold);color:var(--ink)}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  font:600 .95rem/1 Inter,sans-serif;
  padding:.78em 1.15em;border-radius:var(--radius-sm);
  border:1px solid var(--line);background:var(--cloud);color:var(--text);
  cursor:pointer;text-decoration:none;transition:transform .12s, box-shadow .12s, background .12s;
  -webkit-tap-highlight-color:transparent;
}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold);border-color:var(--gold);color:var(--ink);box-shadow:0 4px 14px rgba(221,162,74,.35)}
.btn-gold:hover{background:var(--gold-deep);border-color:var(--gold-deep)}
.btn-ghost{background:transparent}
.btn-sm{padding:.6em .85em;font-size:.86rem;border-radius:9px}
.btn-block{width:100%}
.link-btn{background:none;border:0;color:var(--muted);font:600 .85rem Inter,sans-serif;cursor:pointer;padding:.3em 0}
.link-btn:hover{color:var(--text)}
.link-danger{color:var(--danger)}
.inline{display:inline}
.back{color:var(--muted);text-decoration:none;font-weight:600}

/* ---------- Campos ---------- */
.field{display:block;margin-bottom:14px}
.field>span{display:block;font-size:.82rem;font-weight:600;color:var(--muted);margin-bottom:6px}
input,textarea,select{
  width:100%;font:500 1rem Inter,sans-serif;color:var(--text);
  padding:.8em .9em;border:1px solid #ddd6c8;border-radius:var(--radius-sm);
  background:var(--cloud);transition:border-color .12s, box-shadow .12s;
}
textarea{resize:vertical}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(221,162,74,.18)}
.color-input{height:46px;padding:4px;cursor:pointer}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hint{display:block;color:var(--soft);font-size:.78rem;margin-top:5px}
.hint.center{text-align:center}
.stack{display:flex;flex-direction:column;gap:2px}

/* ---------- Flash / toast ---------- */
.flash{padding:.85em 1em;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:14px}
.flash-err{background:#fbe9e8;color:#a3322d;border:1px solid #f3cfcc}
.flash-ok{background:#e6f4ec;color:#2c7350;border:1px solid #c9e6d6}
.toast{
  position:fixed;left:50%;bottom:calc(var(--tab-h) + 18px);transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:.75em 1.15em;border-radius:999px;
  font-size:.9rem;font-weight:600;box-shadow:var(--shadow);z-index:200;animation:toastIn .25s ease
}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%,0)}}

/* ============================================================
   AUTH (login)
============================================================ */
body.auth{background:radial-gradient(140% 100% at 50% 0%,#2a2548 0%,var(--ink) 60%);min-height:100dvh;display:grid;place-items:center;padding:24px}
.auth-wrap{width:100%;max-width:380px;text-align:center}
.auth-card{background:var(--cloud);border-radius:22px;padding:34px 26px;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.auth-mark{width:54px;height:54px;margin:0 auto 14px;display:grid;place-items:center;border-radius:16px;background:var(--ink);color:var(--gold);font-size:1.5rem}
.auth-title{font-size:1.5rem}
.auth-sub{color:var(--muted);margin:.2em 0 22px;font-size:.92rem}
.auth-card .field{text-align:left}
.auth-foot{color:rgba(255,255,255,.55);font-size:.8rem;margin-top:18px;letter-spacing:.03em}

/* ============================================================
   ADMIN — layout
============================================================ */
body.admin{padding-bottom:calc(var(--tab-h) + env(safe-area-inset-bottom,0px))}
.sidebar{display:none}
.content{padding:18px 16px 28px;max-width:760px;margin:0 auto}

/* barra inferior (mobile) */
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:100;
  display:flex;justify-content:space-around;align-items:stretch;
  height:calc(var(--tab-h) + env(safe-area-inset-bottom,0px));
  padding-bottom:env(safe-area-inset-bottom,0px);
  background:var(--ink);border-top:1px solid var(--ink-3);
}
.tab{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:rgba(255,255,255,.55);text-decoration:none;font-size:.66rem;font-weight:600;letter-spacing:.01em;
}
.tab svg{width:23px;height:23px}
.tab:active{color:#fff}
.tab.is-active,.tab[aria-current]{color:var(--gold)}

/* page head */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:6px 0 20px}
.eyebrow{margin:0 0 2px;font-size:.78rem;font-weight:600;color:var(--gold-deep);text-transform:uppercase;letter-spacing:.08em}
.page-title{font-size:1.7rem;line-height:1.1}
.lead{color:var(--muted);margin:-6px 0 18px;font-size:.95rem}

/* stats */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
.stat{background:var(--ink);color:#fff;border-radius:var(--radius);padding:16px 14px;position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;right:-20px;top:-20px;width:70px;height:70px;border-radius:50%;background:radial-gradient(circle,rgba(221,162,74,.45),transparent 70%)}
.stat-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.9rem;line-height:1}
.stat-num .pct{font-size:1rem;opacity:.7}
.stat-label{margin-top:4px;font-size:.76rem;color:rgba(255,255,255,.65)}

/* panel */
.panel{background:var(--cloud);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);margin-bottom:16px;border:1px solid #ece5d6}
.panel-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;gap:10px}
.panel-title{font-size:1.1rem}
.panel-meta{font-size:.76rem;color:var(--soft)}
.panel-link{font-size:.84rem;font-weight:600;color:var(--gold-deep);text-decoration:none}
.muted{color:var(--muted)}
.empty{text-align:center;padding:30px 16px}
.empty p{color:var(--muted);margin:0 0 14px}

/* ranking */
.rank{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.rank-row{display:flex;gap:12px;align-items:flex-start}
.rank-pos{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;color:var(--soft);width:30px;flex:none;font-size:1rem;padding-top:1px}
.rank-row:first-child .rank-pos{color:var(--gold-deep)}
.rank-body{flex:1;min-width:0}
.rank-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:6px}
.rank-name{font-weight:600;text-decoration:none;color:var(--text)}
.rank-count{font-size:.85rem;color:var(--muted);white-space:nowrap}
.rank-count strong{color:var(--text)}
.bar{height:8px;background:#efe8d9;border-radius:99px;overflow:hidden}
.bar-fill{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold),var(--wine));transition:width .6s cubic-bezier(.2,.8,.2,1)}

/* feed */
.feed{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.feed-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid #f1ebde}
.feed-row:first-child{border-top:0}
.feed-av{width:38px;height:38px;flex:none;border-radius:50%;display:grid;place-items:center;background:var(--ink);color:var(--gold);font-weight:700}
.feed-body{flex:1;min-width:0}
.feed-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-meta{font-size:.8rem;color:var(--muted)}
.feed-time{font-size:.76rem;color:var(--soft);white-space:nowrap}

/* card grid */
.card-grid{display:grid;grid-template-columns:1fr;gap:12px}
.form-card{background:var(--cloud);border:1px solid #ece5d6;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);border-top:3px solid var(--accent,var(--gold))}
.form-card-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.dot{width:8px;height:8px;border-radius:50%}
.dot-on{background:var(--ok)}.dot-off{background:var(--soft)}
.chip{font-size:.72rem;font-weight:700;padding:.2em .6em;border-radius:99px;background:#efe8d9;color:var(--muted)}
.chip-on{background:#e6f4ec;color:#2c7350}
.form-subs{margin-left:auto;font-size:.8rem;color:var(--muted)}
.form-card-title{font-size:1.15rem;margin-bottom:4px}
.form-link{font-size:.84rem;color:var(--gold-deep);font-weight:600;margin-bottom:12px;word-break:break-all}
.form-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.form-card-foot{display:flex;flex-wrap:wrap;gap:14px;align-items:center;padding-top:10px;border-top:1px solid #f1ebde}

/* ============================================================
   BUILDER (formulários)
============================================================ */
.builder{display:flex;flex-direction:column;gap:16px}
.slug-input{display:flex;align-items:center;border:1px solid #ddd6c8;border-radius:var(--radius-sm);overflow:hidden;background:var(--cloud)}
.slug-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(221,162,74,.18)}
.slug-prefix{padding:.8em .2em .8em .9em;color:var(--soft);font-size:.88rem;white-space:nowrap}
.slug-input input{border:0;box-shadow:none!important;padding-left:0}
.logo-up{display:flex;align-items:center;gap:14px}
.logo-prev{width:64px;height:64px;flex:none;border-radius:14px;border:1px dashed #ccc4b2;display:grid;place-items:center;overflow:hidden;background:var(--linen-2)}
.logo-prev img{width:100%;height:100%;object-fit:contain}
.logo-prev span{font-size:.7rem;color:var(--soft)}

.q-list{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}
.q-card{display:flex;gap:8px;background:var(--linen-2);border:1px solid #ece5d6;border-radius:var(--radius-sm);padding:12px;position:relative}
.q-card.dragging{opacity:.5}
.q-grip{cursor:grab;color:var(--soft);font-size:.9rem;line-height:1;letter-spacing:-2px;padding-top:8px;user-select:none}
.q-main{flex:1;min-width:0}
.q-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.q-type-badge{font-size:.72rem;font-weight:700;color:var(--wine);background:#f3e7ee;padding:.2em .6em;border-radius:99px}
.q-name-radio{margin-left:auto;font-size:.78rem;color:var(--muted);display:flex;align-items:center;gap:4px;cursor:pointer}
.q-name-radio input{width:auto;margin:0}
.q-label{font-weight:600}
.q-options{margin-top:10px;display:flex;flex-direction:column;gap:7px}
.opt-row{display:flex;align-items:center;gap:8px}
.opt-dot{width:14px;height:14px;border:2px solid #c9c1b0;border-radius:50%;flex:none}
.opt-input{padding:.5em .7em}
.opt-del{background:none;border:0;color:var(--soft);font-size:1.2rem;cursor:pointer;line-height:1;padding:0 4px}
.add-opt{align-self:flex-start;color:var(--gold-deep)}
.q-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.switch{display:flex;align-items:center;gap:7px;font-size:.84rem;color:var(--muted);cursor:pointer}
.switch input{width:auto;margin:0}
.add-q{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.add-q-label{font-size:.84rem;color:var(--muted);font-weight:600;width:100%}

/* ============================================================
   BADGE STUDIO
============================================================ */
.badge-studio{display:flex;flex-direction:column;gap:16px}
.stage-wrap{display:flex;justify-content:center}
.stage{position:relative;width:100%;max-width:380px;aspect-ratio:1/1.4;background:var(--linen-2);border-radius:14px;overflow:hidden;border:1px solid #e7e0d0;touch-action:none}
.stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;pointer-events:none;user-select:none}
.stage-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);text-align:center;padding:20px}
.drag-box{position:absolute;transform:translate(-50%,-50%);background:rgba(221,162,74,.18);border:1.5px dashed var(--gold-deep);border-radius:8px;padding:6px 10px;cursor:grab;white-space:nowrap;backdrop-filter:blur(1px);touch-action:none}
.drag-box span{pointer-events:none;font-weight:700;font-size:13px;font-family:'Bricolage Grotesque',sans-serif}
.drag-box.dragging{cursor:grabbing;background:rgba(221,162,74,.32)}
.drag-qr{display:grid;place-items:center;background:rgba(110,50,87,.18);border-color:var(--wine);width:64px;height:64px;padding:0}
.drag-qr span{font-size:11px;color:var(--wine)}
.controls-panel{display:flex;flex-direction:column;gap:6px}
.ctl-group{border-top:1px solid #f1ebde;padding-top:12px;margin-top:6px}
.ctl-group h3{font-size:.92rem;margin-bottom:10px;color:var(--wine)}
input[type=range]{accent-color:var(--gold-deep)}

.gen-actions{display:flex;gap:8px;flex-wrap:wrap}
.gen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.gen-card{border:1px solid #ece5d6;border-radius:12px;overflow:hidden;background:var(--linen-2)}
.gen-thumb{width:100%;height:auto;display:block;background:#fff}
.gen-card-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px}
.gen-card-bar span{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ============================================================
   INSCRIÇÕES
============================================================ */
.filters{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.search{display:flex;gap:8px}
.search input{flex:1}
.sub-list{display:flex;flex-direction:column;gap:8px}
.sub-item{background:var(--cloud);border:1px solid #ece5d6;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.sub-item summary{display:flex;align-items:center;gap:11px;padding:12px 14px;cursor:pointer;list-style:none}
.sub-item summary::-webkit-details-marker{display:none}
.sub-av{width:36px;height:36px;flex:none;border-radius:50%;background:var(--wine);color:#fff;display:grid;place-items:center;font-weight:700}
.sub-info{flex:1;min-width:0}
.sub-name{font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub-sub{font-size:.78rem;color:var(--muted)}
.sub-time{font-size:.72rem;color:var(--soft);white-space:nowrap}
.tag{font-size:.68rem;font-weight:700;padding:.2em .55em;border-radius:99px;background:#efe8d9;color:var(--muted)}
.tag-ok{background:#e6f4ec;color:#2c7350}
.sub-detail{padding:0 14px 14px;border-top:1px solid #f1ebde}
.ans{padding:9px 0;border-bottom:1px solid #f4eee2}
.ans-q{display:block;font-size:.74rem;font-weight:700;color:var(--soft);text-transform:uppercase;letter-spacing:.04em}
.ans-v{display:block;margin-top:2px}
.sub-detail-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}

/* admins */
.admin-form .field-row{margin-bottom:0}
.admin-list{display:flex;flex-direction:column;gap:2px}
.admin-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid #f1ebde}
.admin-row:first-child{border-top:0}
.admin-av{width:40px;height:40px;flex:none;border-radius:50%;background:var(--ink);color:var(--gold);display:grid;place-items:center;font-weight:700}
.admin-meta{flex:1;min-width:0}
.admin-name{font-weight:600}
.admin-email{font-size:.8rem;color:var(--muted)}
.pass-reset{display:flex;gap:6px;align-items:center;margin-top:6px}
.pass-reset input{padding:.4em .6em;font-size:.82rem;max-width:160px}
.admin-actions{display:flex;align-items:center;gap:10px}
.role-sel{width:auto;padding:.4em .5em;font-size:.82rem}

/* ============================================================
   PÚBLICO (formulário / sucesso / verificação)
============================================================ */
body.public{background:radial-gradient(120% 90% at 50% -10%,#fffdf8,var(--linen));min-height:100dvh}
.form-wrap{max-width:520px;margin:0 auto;padding:26px 18px 50px}
.form-head{text-align:center;margin-bottom:22px}
.form-logo{max-height:84px;width:auto;margin:0 auto 14px;object-fit:contain}
.form-mark{width:56px;height:56px;margin:0 auto 14px;display:grid;place-items:center;border-radius:16px;background:var(--ink);color:var(--accent);font-size:1.6rem}
.form-title{font-size:1.7rem;line-height:1.15}
.form-desc{color:var(--muted);margin-top:8px}
.pub-form{display:flex;flex-direction:column;gap:18px}
.pub-field{background:var(--cloud);border:1px solid #ece5d6;border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow-sm)}
.pub-label{display:block;font-weight:600;margin-bottom:9px}
.req{color:var(--danger);margin-left:3px}
.choices{display:flex;flex-direction:column;gap:8px}
.choice{display:flex;align-items:center;gap:11px;padding:.7em .8em;border:1px solid #e4ddcd;border-radius:var(--radius-sm);cursor:pointer;transition:border-color .12s,background .12s}
.choice:has(input:checked){border-color:var(--accent);background:rgba(221,162,74,.1)}
.choice input{width:auto;margin:0;accent-color:var(--accent)}
.btn-submit{
  width:100%;border:0;border-radius:var(--radius-sm);cursor:pointer;
  padding:1em;font:700 1.05rem 'Bricolage Grotesque',sans-serif;
  background:var(--accent);color:var(--ink);box-shadow:0 6px 18px rgba(221,162,74,.4);
  transition:transform .12s
}
.btn-submit:active{transform:translateY(1px)}
.closed-note{text-align:center;background:var(--cloud);border:1px solid #ece5d6;border-radius:var(--radius);padding:22px;color:var(--muted)}
.form-foot{text-align:center;color:var(--soft);font-size:.78rem;margin-top:28px;letter-spacing:.04em}

/* sucesso */
.success-card,.verify-card{background:var(--cloud);border:1px solid #ece5d6;border-radius:22px;padding:30px 22px;text-align:center;box-shadow:var(--shadow)}
.success-check{width:58px;height:58px;margin:0 auto 14px;border-radius:50%;background:#e6f4ec;color:var(--ok);display:grid;place-items:center;font-size:1.7rem;font-weight:700}
.success-title{font-size:1.5rem}
.success-sub{color:var(--gold-deep);font-weight:600;margin-top:4px}
.success-name{font-size:1.1rem;font-weight:600;margin-top:10px}
.ticket{display:flex;align-items:center;gap:16px;justify-content:center;background:var(--linen-2);border:1px dashed #d8cfba;border-radius:16px;padding:18px;margin:20px 0}
.ticket-qr{flex:none}
.ticket-qr img,.ticket-qr canvas{border-radius:8px}
.ticket-code{text-align:left}
.ticket-code span{display:block;font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.ticket-code strong{font-family:'Bricolage Grotesque',sans-serif;font-size:1.6rem;letter-spacing:.12em;color:var(--ink)}
.success-hint{color:var(--muted);font-size:.88rem;margin-top:6px}
.success-hint a{color:var(--gold-deep);font-weight:600}

/* verify */
.verify-status{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.3em .8em;border-radius:99px;background:#efe8d9;color:var(--muted)}
.verify-status.is-in{background:#e6f4ec;color:#2c7350}
.verify-name{font-size:1.6rem;margin-top:14px}
.verify-form{color:var(--gold-deep);font-weight:600}
.verify-code{font-family:'Bricolage Grotesque',sans-serif;font-size:1.4rem;letter-spacing:.16em;color:var(--ink);margin:14px 0}
.verify-detail{text-align:left;margin:18px 0;border-top:1px solid #f1ebde}

/* ============================================================
   DESKTOP — sidebar
============================================================ */
@media (min-width:900px){
  .tabbar{display:none}
  body.admin{padding-bottom:0}
  .sidebar{
    display:flex;flex-direction:column;
    position:fixed;left:0;top:0;bottom:0;width:248px;
    background:var(--ink);color:#fff;padding:24px 18px;
  }
  .brand{display:flex;align-items:center;gap:11px;margin-bottom:30px;padding:0 6px}
  .brand-mark{width:38px;height:38px;display:grid;place-items:center;border-radius:11px;background:var(--ink-3);color:var(--gold);font-size:1.2rem}
  .brand-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.1rem}
  .side-nav{display:flex;flex-direction:column;gap:4px;flex:1}
  .nav-item{display:flex;align-items:center;gap:12px;padding:.7em .8em;border-radius:11px;color:rgba(255,255,255,.66);text-decoration:none;font-weight:600;font-size:.94rem;transition:background .12s,color .12s}
  .nav-item svg{width:21px;height:21px}
  .nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
  .nav-item.is-active{background:var(--gold);color:var(--ink)}
  .side-foot{display:flex;align-items:center;gap:10px;border-top:1px solid var(--ink-3);padding-top:16px;margin-top:10px}
  .who{flex:1;min-width:0}
  .who-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .who-role{font-size:.76rem;color:rgba(255,255,255,.5)}
  .logout{width:38px;height:38px;flex:none;display:grid;place-items:center;border-radius:10px;background:rgba(255,255,255,.08);color:#fff}
  .logout svg{width:19px;height:19px}
  .content{margin-left:248px;max-width:1500px;padding:36px clamp(28px,4vw,64px)}
  .stat-grid{gap:16px}
  .stat{padding:24px}
  .stat-num{font-size:2.4rem}
  .card-grid{grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:18px}
  /* painéis de conteúdo "largo" não precisam esticar texto infinitamente */
  .panel{max-width:1280px}
  .stat-grid{max-width:1280px}
  .page-head{max-width:1280px}
  .builder{display:grid;grid-template-columns:1fr;gap:16px}
  .badge-studio{flex-direction:row;align-items:flex-start}
  .stage-panel{flex:1}
  .controls-panel{width:300px;flex:none;position:sticky;top:34px}
  .gen-grid{grid-template-columns:repeat(3,1fr)}
  .filters{flex-direction:row;align-items:center}
  .filters select{width:auto;min-width:220px}
  .search{flex:1}
}

@media (min-width:560px){
  .gen-grid{grid-template-columns:repeat(3,1fr)}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ============================================================
   v2 — temas de fundo, cards coloridos, scanner, pedidos
============================================================ */

/* Temas de fundo do painel */
body.admin[data-theme=cloud]{background:#EEF1F7}
body.admin[data-theme=sand]{background:#F3EAD9}
body.admin[data-theme=rose]{background:#F7EFEF}
body.admin[data-theme=mint]{background:#EAF4EE}
body.admin[data-theme=night]{background:#211F33}
body.admin[data-theme=night] .page-title,
body.admin[data-theme=night] .lead{color:#F6F1E8}
body.admin[data-theme=night] .back{color:#b9b3cf}

.brand-logo{width:38px;height:38px;border-radius:10px;object-fit:cover;background:#fff}

/* Stats coloridos e preenchidos */
.stat{border:0}
.stat-grid .stat:nth-child(1){background:linear-gradient(150deg,#2a2548,#1E1B33)}
.stat-grid .stat:nth-child(2){background:linear-gradient(150deg,#7d3a61,#5d2a49)}
.stat-grid .stat:nth-child(2)::after{background:radial-gradient(circle,rgba(221,162,74,.5),transparent 70%)}
.stat-grid .stat:nth-child(3){background:linear-gradient(150deg,#b9822f,#8a5d1d)}
.stat-grid .stat:nth-child(3)::after{background:radial-gradient(circle,rgba(255,255,255,.35),transparent 70%)}

/* Cards de formulário/pedido — coloridos e preenchidos pela cor de destaque */
.form-card,.order-card{
  border:1px solid color-mix(in srgb, var(--accent,#DDA24A) 38%, #e7dfce);
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--accent,#DDA24A) 16%, #fff) 0%,
    color-mix(in srgb, var(--accent,#DDA24A) 5%, #fff) 60%, #fff 100%);
  border-top-width:3px;border-top-color:var(--accent,#DDA24A);
}
.form-card-title,.order-card .form-card-title{color:var(--ink)}
.form-card .chip,.order-card .chip{background:color-mix(in srgb,var(--accent,#DDA24A) 22%, #fff);color:#6b4e1a}

/* Estatística dentro do card de pedido */
.order-stats{display:flex;gap:10px;margin:6px 0 12px}
.order-stats>div{flex:1;background:rgba(255,255,255,.6);border:1px solid color-mix(in srgb,var(--accent,#DDA24A) 25%,#eee);border-radius:11px;padding:9px 11px}
.order-stats strong{display:block;font-family:'Bricolage Grotesque',sans-serif;font-size:1.05rem;color:var(--ink)}
.order-stats span{font-size:.72rem;color:var(--muted)}

/* Cores no feed/inscrições para alegrar */
.feed-row:nth-child(5n+1) .feed-av{background:var(--ink)}
.feed-row:nth-child(5n+2) .feed-av{background:var(--wine)}
.feed-row:nth-child(5n+3) .feed-av{background:var(--gold-deep)}
.feed-row:nth-child(5n+4) .feed-av{background:#3a6b54}
.feed-row:nth-child(5n+5) .feed-av{background:#3b5ba9}

/* Local */
.form-local{margin-top:10px;display:inline-block;background:color-mix(in srgb,var(--accent) 16%,#fff);color:#6b4e1a;font-weight:600;font-size:.85rem;padding:.4em .8em;border-radius:99px}
.success-local{margin-top:10px;color:var(--muted);font-size:.9rem}

/* ---------- Menu "Mais" (mobile) ---------- */
.more-backdrop{position:fixed;inset:0;background:rgba(20,18,36,.5);opacity:0;visibility:hidden;transition:opacity .2s;z-index:140}
.more-backdrop.is-open{opacity:1;visibility:visible}
.more-sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:150;background:var(--cloud);
  border-radius:20px 20px 0 0;padding:10px 14px calc(18px + env(safe-area-inset-bottom));
  transform:translateY(110%);transition:transform .25s cubic-bezier(.2,.8,.2,1);box-shadow:0 -10px 40px rgba(0,0,0,.25)
}
.more-sheet.is-open{transform:translateY(0)}
.more-grip{width:40px;height:4px;border-radius:99px;background:#d8d0c0;margin:6px auto 12px}
.more-link{display:flex;align-items:center;gap:14px;padding:14px 10px;text-decoration:none;color:var(--text);font-weight:600;border-radius:12px}
.more-link svg{width:22px;height:22px;color:var(--gold-deep)}
.more-link:active{background:var(--linen-2)}
.more-logout{color:var(--danger)}.more-logout svg{color:var(--danger)}

/* ---------- Ajustes: temas ---------- */
.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.theme-opt{cursor:pointer;text-align:center}
.theme-opt input{position:absolute;opacity:0;pointer-events:none}
.theme-swatch{display:block;height:54px;border-radius:12px;border:2px solid #e3dccb;box-shadow:inset 0 0 0 3px #fff}
.theme-opt input:checked+.theme-swatch{border-color:var(--gold-deep);box-shadow:inset 0 0 0 3px #fff,0 0 0 3px rgba(221,162,74,.3)}
.theme-label{display:block;margin-top:6px;font-size:.82rem;font-weight:600;color:var(--muted)}

/* ---------- Scanner ---------- */
.scan-reader{width:100%;max-width:360px;margin:14px auto 0;border-radius:16px;overflow:hidden;background:#000;min-height:180px}
.scan-reader video{width:100%!important;display:block}
.scan-controls{display:flex;gap:10px;justify-content:center;margin-top:14px}
.scan-err{color:#fff;text-align:center;padding:30px 16px}
.scan-result{margin-top:6px;text-align:center;border-radius:18px;padding:26px 20px;color:#fff;animation:pop .25s ease}
@keyframes pop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.scan-result.is-valid{background:linear-gradient(150deg,#2f9b66,#1f6f48)}
.scan-result.is-invalid{background:linear-gradient(150deg,#c4453f,#8f2f2b)}
.scan-badge{width:64px;height:64px;margin:0 auto 12px;border-radius:50%;background:rgba(255,255,255,.2);display:grid;place-items:center;font-size:2rem;font-weight:700}
.scan-name{font-family:'Bricolage Grotesque',sans-serif;font-size:1.5rem;font-weight:800}
.scan-form{opacity:.9;margin-top:2px}
.scan-status{margin-top:10px;font-weight:600}
.scan-code{margin-top:6px;font-family:'Bricolage Grotesque',sans-serif;letter-spacing:.14em;opacity:.85}

/* ---------- Produtos (admin) ---------- */
.prod-admin-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.prod-admin{border:1px solid #ece5d6;border-radius:12px;background:var(--linen-2);overflow:hidden}
.prod-admin summary{display:flex;align-items:center;gap:12px;padding:10px 12px;cursor:pointer;list-style:none}
.prod-admin summary::-webkit-details-marker{display:none}
.prod-thumb{width:46px;height:46px;flex:none;border-radius:10px;background:#fff;border:1px solid #eee;display:grid;place-items:center;overflow:hidden;font-size:1.3rem}
.prod-thumb img{width:100%;height:100%;object-fit:cover}
.prod-info{flex:1;min-width:0}
.prod-name{font-weight:600;display:block}
.prod-price{font-size:.84rem;color:var(--gold-deep);font-weight:700}
.prod-price em{color:var(--muted);font-weight:600}
.prod-edit{padding:4px 12px 12px;border-top:1px solid #efe8d9}
.prod-edit-actions{margin-top:6px}
.prod-del{padding:0 12px 12px}
.add-prod{border-top:1px dashed #ddd4c0;padding-top:16px}
.add-prod h3{font-size:1rem;margin-bottom:12px;color:var(--wine)}

/* ---------- Produtos (público) ---------- */
.order-wrap{max-width:680px}
.prod-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:8px}
.prod-card{display:flex;gap:14px;background:var(--cloud);border:1px solid #ece5d6;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}
.prod-card.is-picked{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent)}
.prod-img{width:104px;flex:none;background:var(--linen-2);display:grid;place-items:center;overflow:hidden}
.prod-img img{width:100%;height:100%;object-fit:cover}
.prod-img span{font-size:2rem}
.prod-body{flex:1;min-width:0;padding:13px 14px 13px 0;display:flex;flex-direction:column}
.prod-title{font-size:1.05rem;margin-bottom:3px}
.prod-desc{font-size:.84rem;color:var(--muted);margin-bottom:10px;flex:1}
.prod-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.prod-card .prod-price{font-size:1.05rem}
.qty{display:flex;align-items:center;gap:2px;background:var(--linen-2);border:1px solid #e3dccb;border-radius:99px;padding:3px}
.qty-btn{width:32px;height:32px;border:0;border-radius:50%;background:var(--cloud);font-size:1.2rem;line-height:1;cursor:pointer;color:var(--ink);box-shadow:var(--shadow-sm)}
.qty-btn:active{transform:scale(.92)}
.qty-input{width:34px;border:0;background:transparent;text-align:center;font-weight:700;padding:0;font-size:1rem}
.qty-input:focus{box-shadow:none}

/* barra de total fixa */
.order-bar{position:sticky;bottom:14px;display:flex;align-items:center;gap:14px;background:var(--ink);color:#fff;border-radius:16px;padding:12px 14px;box-shadow:0 12px 30px rgba(30,27,51,.3);margin-top:6px}
.order-bar-total{display:flex;flex-direction:column;line-height:1.1}
.order-bar-total span{font-size:.72rem;color:rgba(255,255,255,.6)}
.order-bar-total strong{font-family:'Bricolage Grotesque',sans-serif;font-size:1.4rem}
.order-bar .btn-submit{flex:1;margin:0;width:auto}

/* tabela de itens do pedido */
.order-items{width:100%;border-collapse:collapse;margin:10px 0}
.order-items td{padding:7px 4px;border-bottom:1px solid #f1ebde;font-size:.9rem;vertical-align:top}
.order-items td.num{text-align:right;white-space:nowrap;font-weight:600}
.order-items td:first-child{width:34px;color:var(--gold-deep);font-weight:700}
.order-items-total td{border-top:2px solid #e3dccb;border-bottom:0;font-weight:700;padding-top:9px}
.order-items.receipt{text-align:left}
.order-total{margin-left:auto;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;color:var(--ink);white-space:nowrap}
.order-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.84rem;margin:8px 0}
.order-note{background:var(--linen-2);border-radius:10px;padding:10px 12px;font-size:.88rem;color:var(--text)}
.tag-no{background:#fbe9e8;color:#a3322d}
.ticket-code.center{text-align:center;margin:18px 0}
.ticket-code.center span{display:block}

@media (min-width:760px){
  .prod-grid{grid-template-columns:1fr 1fr}
}

/* ---------- Código do evento (Inscrições) ---------- */
.event-code-card{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg,#26223f,#1E1B33);color:#fff;border-radius:var(--radius);
  padding:16px 18px;margin-bottom:16px;box-shadow:var(--shadow)
}
.ecc-label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.6)}
.ecc-code{display:block;font-family:'Bricolage Grotesque',sans-serif;font-size:1.9rem;letter-spacing:.18em;color:var(--gold);margin:2px 0}
.ecc-hint{display:block;font-size:.8rem;color:rgba(255,255,255,.7);max-width:46ch}
.ecc-actions{display:flex;gap:8px;flex-wrap:wrap}

.prod-noprice{color:var(--muted);font-weight:600;font-size:.85rem}

/* ============================================================
   VALIDADOR (público, tela cheia)
============================================================ */
body.validator{background:#16142b;min-height:100dvh;color:#fff}
.val-setup{min-height:100dvh;display:grid;place-items:center;padding:24px}
.val-card{background:#221f3a;border:1px solid #322c52;border-radius:22px;padding:30px 24px;width:100%;max-width:380px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.val-mark{width:54px;height:54px;margin:0 auto 14px;display:grid;place-items:center;border-radius:16px;background:#16142b;color:var(--gold);font-size:1.5rem}
.val-title{font-size:1.5rem}
.val-sub{color:#b9b3cf;margin:.3em 0 18px;font-size:.92rem}
.val-card .field{text-align:left}
.val-card .field>span{color:#cdc7e6}
.val-card input{background:#16142b;border-color:#3a3458;color:#fff}
.val-hint{color:#8580a0;font-size:.8rem;margin-top:14px}
.val-hint strong{color:#cdc7e6}

.val-app{max-width:520px;margin:0 auto;padding:14px 14px calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:12px;min-height:100dvh}
.val-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 4px}
.val-event{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.05rem}
.val-who{font-size:.8rem;color:#9a95b5}
.val-switch{background:#2a2647;border:1px solid #3a3458;color:#cdc7e6;border-radius:99px;padding:.4em .9em;font-size:.8rem;font-weight:600;cursor:pointer}

.val-result{border-radius:20px;padding:22px;text-align:center;background:#221f3a;border:1px solid #322c52;min-height:128px;display:flex;flex-direction:column;justify-content:center;transition:background .15s}
.val-result.is-ok{background:linear-gradient(150deg,#2f9b66,#1f6f48);border-color:transparent;animation:pop .2s}
.val-result.is-repeat{background:linear-gradient(150deg,#c89a3a,#9a7423);border-color:transparent;animation:pop .2s}
.val-result.is-bad{background:linear-gradient(150deg,#c4453f,#8f2f2b);border-color:transparent;animation:pop .2s}
.val-idle{color:#9a95b5}
.val-big{font-size:2.6rem;font-weight:800;line-height:1}
.val-name{font-family:'Bricolage Grotesque',sans-serif;font-size:1.6rem;font-weight:800;margin-top:6px}
.val-msg{margin-top:4px;font-weight:600;opacity:.95}

.val-reader{width:100%;border-radius:18px;overflow:hidden;background:#000;min-height:220px}
.val-reader video{width:100%!important;display:block}
.val-camerr{color:#cdc7e6;text-align:center;padding:30px 16px}

.val-manual{display:flex;gap:8px}
.val-manual input{flex:1;background:#221f3a;border-color:#3a3458;color:#fff;text-transform:uppercase;letter-spacing:.1em}

.val-log{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.val-log-row{display:flex;align-items:center;gap:10px;background:#221f3a;border:1px solid #2e2a48;border-radius:11px;padding:9px 12px}
.val-log-row.ok{border-left:3px solid #3f9b6a}
.val-log-row.repeat{border-left:3px solid #d9a93a}
.val-log-row.bad{border-left:3px solid #c4453f}
.val-log-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;width:32px;color:#b9b3cf}
.val-log-name{flex:1;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.val-log-time{font-size:.76rem;color:#8580a0}

/* ============================================================
   COMPROVANTE (documento para PDF via html2canvas)
============================================================ */
.pdf-stage{position:fixed;left:-9999px;top:0}
.receipt-doc{width:720px;background:#fff;color:#211F33;font-family:Inter,sans-serif;box-sizing:border-box}
.receipt-band{background:#1E1B33;color:#fff;padding:22px 32px;display:flex;align-items:center;justify-content:space-between}
.receipt-band .rb-site{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:20px;letter-spacing:.02em;color:#DDA24A}
.receipt-band .rb-kind{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.receipt-accent{height:5px;background:linear-gradient(90deg,#DDA24A,#6E3257)}
.receipt-body{padding:30px 32px 34px}
.receipt-h1{font-family:'Bricolage Grotesque',sans-serif;font-size:26px;font-weight:800;line-height:1.12;margin:0 0 4px;color:#1E1B33}
.receipt-sub{color:#6E3257;font-weight:700;font-size:14px;margin:0 0 18px}
.receipt-top{display:flex;gap:26px;align-items:center;border:1px solid #ece5d6;border-radius:16px;padding:20px;background:#FBF8F2}
.receipt-qr{flex:none;width:150px;height:150px;background:#fff;border-radius:10px;padding:6px;box-sizing:border-box}
.receipt-qr img{width:100%;height:100%;display:block}
.receipt-idblock{flex:1}
.receipt-name{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:800;margin:0 0 10px}
.receipt-codelabel{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#9a96ad}
.receipt-code{font-family:'Bricolage Grotesque',sans-serif;font-size:30px;letter-spacing:.16em;color:#C8862F;font-weight:800;line-height:1}
.receipt-meta{display:flex;flex-wrap:wrap;gap:10px 26px;margin:20px 0 8px}
.receipt-meta .rm{min-width:160px}
.receipt-meta .rm-l{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#9a96ad;font-weight:700}
.receipt-meta .rm-v{font-size:15px;margin-top:2px}
.receipt-sec-title{font-family:'Bricolage Grotesque',sans-serif;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:#6E3257;margin:22px 0 10px;font-weight:700}
.receipt-fields{border-top:1px solid #efe8d9}
.receipt-field{padding:11px 0;border-bottom:1px solid #efe8d9;display:flex;gap:18px}
.receipt-field .rf-q{flex:none;width:200px;font-size:12px;font-weight:700;color:#9a96ad;text-transform:uppercase;letter-spacing:.03em}
.receipt-field .rf-v{flex:1;font-size:15px}
.receipt-items{width:100%;border-collapse:collapse;margin-top:4px}
.receipt-items th{text-align:left;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#9a96ad;border-bottom:2px solid #e3dccb;padding:8px 6px}
.receipt-items td{padding:11px 6px;border-bottom:1px solid #efe8d9;font-size:15px;vertical-align:middle}
.receipt-items .ri-q{width:50px;color:#C8862F;font-weight:800}
.receipt-items .ri-pic{width:54px}
.receipt-items .ri-pic img{width:46px;height:46px;object-fit:cover;border-radius:8px;display:block}
.receipt-items .num{text-align:right;white-space:nowrap;font-weight:700;width:110px}
.receipt-total-row td{border-bottom:0;border-top:2px solid #1E1B33;padding-top:14px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:18px}
.receipt-foot{margin-top:26px;padding-top:16px;border-top:1px solid #efe8d9;display:flex;justify-content:space-between;align-items:center;color:#9a96ad;font-size:12px}
.receipt-foot .rf-badge{display:inline-flex;align-items:center;gap:7px;color:#6E3257;font-weight:700}

/* botão único de download em telas públicas */
.dl-only{margin-top:6px}

/* ============================================================
   MONITOR DE PRESENÇA (admin "Verificar crachá")
============================================================ */
.monitor-hero{display:flex;gap:18px;flex-wrap:wrap}
.mon-big{flex:1;min-width:200px;background:linear-gradient(150deg,#2f9b66,#1f6f48);color:#fff;border-radius:var(--radius);padding:22px 24px;position:relative;overflow:hidden}
.mon-big::after{content:"";position:absolute;right:-20px;top:-20px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.25),transparent 70%)}
.mon-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:3rem;line-height:1}
.mon-num small{font-size:1.2rem;opacity:.8;font-weight:700}
.mon-label{margin-top:4px;font-size:.85rem;color:rgba(255,255,255,.8)}
.mon-side{flex:1;min-width:200px;background:var(--ink);color:#fff;border-radius:var(--radius);padding:22px 24px}
.mon-side .mon-num{color:var(--gold)}
.mon-side .mon-label{color:rgba(255,255,255,.65)}
.mon-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.mon-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid #f1ebde}
.mon-row:first-child{border-top:0}
.mon-av{width:36px;height:36px;flex:none;border-radius:50%;background:#2f9b66;color:#fff;display:grid;place-items:center;font-weight:700}
.mon-info{flex:1;min-width:0}
.mon-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mon-meta{font-size:.78rem;color:var(--muted)}
.mon-time{font-size:.78rem;color:var(--soft);white-space:nowrap}
.mon-refresh{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--muted)}
.mon-dot{width:8px;height:8px;border-radius:50%;background:#2f9b66;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* validador: campo do código do evento via link */
.val-prefilled{background:#1f6f48;border-color:transparent}

/* ---------- Construtor de produtos ---------- */
.item-card{background:var(--linen-2)}
.item-row{display:flex;gap:14px}
.item-photo{flex:none;width:92px;display:flex;flex-direction:column;align-items:center;gap:6px}
.item-prev{width:92px;height:92px;border-radius:12px;border:1px dashed #ccc4b2;background:#fff;display:grid;place-items:center;overflow:hidden;cursor:pointer}
.item-prev img{width:100%;height:100%;object-fit:cover}
.item-prev span{font-size:.72rem;color:var(--soft)}
.item-upload{color:var(--gold-deep)}
.item-fields{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}
.item-title{font-weight:600}
.item-foot{display:flex;align-items:center;gap:16px;margin-top:12px;flex-wrap:wrap}
.item-price-field{margin:0;width:130px}
.item-price-field>span{margin-bottom:4px}
.item-foot .switch{margin-top:0}
.item-foot .item-del{margin-left:auto}
