/* ==========================================================================
   Hexa Studio — Design System v3 (DARK, preto + laranja Hexa)
   Fundo escuro #161617, laranja #FF6600 (ação/destaque), fonte Inter.
   ========================================================================== */

:root{
  /* superfícies */
  --bg:#161617;          --bg-soft:#1c1c1e;     --surface:#202023;   --surface-2:#27272b;
  --sidebar:#0e0e10;
  /* marca (laranja Hexa) */
  --primary:#FF6600;     --primary-600:#ff7d29; --primary-700:#e85c00;
  --accent:#ff8a3d;      --accent-soft:rgba(255,102,0,.15);
  /* texto */
  --heading:#ffffff;     --text:#e7e7ea;        --muted:#9a9aa4;     --muted-2:#6f6f79;
  --navy:#ffffff;        /* compat: usado como cor de títulos em regras antigas */
  /* utilidade */
  --line:#2e2e34;        --line-2:#3b3b43;
  --ok:#2ecc71;          --ok-soft:rgba(46,204,113,.14);
  --warn:#fcb900;        --warn-soft:rgba(252,185,0,.14);
  --danger:#ff5a4d;      --danger-soft:rgba(255,90,77,.14);
  --info:#4aa3ff;        --info-soft:rgba(74,163,255,.14);
  /* forma */
  --r-sm:9px; --r:13px; --r-lg:18px; --r-xl:24px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 6px 18px rgba(0,0,0,.45);
  --shadow-lg:0 22px 55px rgba(0,0,0,.6);
  --ring:0 0 0 4px rgba(255,102,0,.22);
  --sidebar-w:256px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--text);
  font-size:15px; line-height:1.55; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5{font-family:'Inter',sans-serif;font-weight:800;margin:0 0 .4em;color:var(--heading);line-height:1.2;letter-spacing:-.01em}
h1{font-size:24px} h2{font-size:20px} h3{font-size:17px}
a{color:var(--accent)}
a:hover{color:var(--primary)}
small,.muted{color:var(--muted)}
hr{border:0;border-top:1px solid var(--line);margin:18px 0}
svg{display:block}
.icon{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}
.icon-sm{width:16px;height:16px}

/* ---- Botões (suporta .btn e .bt) ---- */
.btn,.bt{display:inline-flex;align-items:center;gap:8px;justify-content:center;
  border:1px solid transparent;border-radius:var(--r);padding:11px 18px;font-size:14.5px;font-weight:600;
  font-family:inherit;cursor:pointer;transition:.16s ease;text-decoration:none;line-height:1;white-space:nowrap}
.btn:active,.bt:active{transform:translateY(1px)}
.btn-primary,.bt-primary{background:var(--primary);color:#fff;box-shadow:0 6px 16px rgba(255,102,0,.35)}
.btn-primary:hover,.bt-primary:hover{background:var(--primary-600);color:#fff}
.btn-accent,.bt-accent{background:var(--primary);color:#fff;box-shadow:0 6px 16px rgba(255,102,0,.35)}
.btn-accent:hover,.bt-accent:hover{background:var(--primary-600);color:#fff}
.btn-ghost,.bt-outline,.bt-ghost{background:var(--surface-2);color:var(--text);border-color:var(--line-2)}
.btn-ghost:hover,.bt-outline:hover{border-color:var(--primary);color:#fff}
.btn-danger{background:transparent;border-color:var(--danger);color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:#fff}
.btn-sm,.bt-small{padding:8px 13px;font-size:13px;border-radius:var(--r-sm)}
.btn-block,.bt-block{width:100%}
.btn-lg{padding:14px 22px;font-size:16px}

/* ---- Cards / superfícies ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm)}
.card-2{background:var(--surface-2)}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.between{justify-content:space-between}
.spacer{flex:1}

/* ---- Formulários ---- */
label{display:block;font-size:13px;color:var(--muted);margin:0 0 6px;font-weight:600}
.field{margin-bottom:16px}
input,select,textarea,.form-input{
  width:100%;background:var(--bg-soft);border:1px solid var(--line-2);color:var(--text);
  border-radius:var(--r-sm);padding:12px 14px;font-size:15px;font-family:inherit;outline:none;transition:.16s}
input::placeholder,textarea::placeholder{color:var(--muted-2)}
input:focus,select:focus,textarea:focus,.form-input:focus{border-color:var(--primary);box-shadow:var(--ring)}
select option{background:var(--surface)}
textarea{resize:vertical;min-height:96px}
input[type=color]{padding:4px;height:48px;cursor:pointer;background:var(--bg-soft)}
.input-hint{font-size:12px;color:var(--muted-2);margin-top:5px}

/* input com ícone */
.input-group{position:relative;display:flex;align-items:center}
.input-group .input-group__addon{position:absolute;left:13px;color:var(--muted-2);display:flex;pointer-events:none}
.input-group .input-group__addon.right{left:auto;right:13px;pointer-events:auto;cursor:pointer}
.input-group input{padding-left:42px}
.input-group input.has-right{padding-right:42px}

/* ---- Badges ---- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:700}
.badge-azul{background:var(--accent-soft);color:var(--accent)}
.badge-ok{background:var(--ok-soft);color:#5fe0a0}
.badge-erro{background:var(--danger-soft);color:#ff9087}
.badge-aviso{background:var(--warn-soft);color:#ffd35e}
.badge-muted{background:rgba(255,255,255,.08);color:var(--muted)}

/* ---- Layout app ---- */
.app{display:flex;min-height:100vh}
.sidebar{display:none}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;
  padding:12px 16px;background:rgba(22,22,23,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .brand{font-weight:800;color:var(--heading);font-size:18px;letter-spacing:-.02em}
.topbar .brand b{color:var(--primary)}
.content{padding:18px 16px 96px;max-width:1240px;width:100%;margin:0 auto}

.logo-chip{background:var(--primary);color:#fff;font-weight:800;
  padding:7px 11px;border-radius:10px;font-size:13px;letter-spacing:.3px}

/* seletor de cliente */
.client-switch{display:flex;align-items:center;gap:8px;background:var(--surface-2);
  border:1px solid var(--line-2);border-radius:999px;padding:5px 8px 5px 12px;max-width:210px}
.client-switch select{border:0;background:transparent;padding:4px;font-size:13px;font-weight:700;color:var(--heading)}
.client-switch select:focus{box-shadow:none}
.client-switch .dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex:0 0 auto}

/* avatar */
.avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:0 0 auto}

/* sino de notificações */
.topbar-bell{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;color:var(--muted);border:1px solid var(--line-2)}
.topbar-bell:hover{color:var(--heading);background:var(--surface-2)}
.notif-dot{position:absolute;top:-3px;right:-3px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.bottomnav .notif-dot{top:4px;right:50%;margin-right:-20px}

/* ---- Bottom nav (mobile) ---- */
.bottomnav{position:fixed;bottom:0;left:0;right:0;z-index:40;display:flex;
  background:rgba(14,14,16,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom)}
.bottomnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:9px 2px 8px;color:var(--muted-2);font-size:10.5px;font-weight:600}
.bottomnav a.active{color:var(--primary)}
.bottomnav a .icon{width:22px;height:22px}
.bottomnav .fab{flex:0 0 auto;margin-top:-22px}
.bottomnav .fab .b{width:56px;height:56px;border-radius:50%;background:var(--primary);
  color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px rgba(255,102,0,.5)}
.bottomnav .fab .b .icon{width:26px;height:26px;stroke-width:2.4}

/* ---- Métricas ---- */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.stat .n{font-weight:800;font-size:28px;color:var(--heading);letter-spacing:-.02em}
.stat .l{font-size:12.5px;color:var(--muted);font-weight:500}
.stat .ico{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:10px;
  background:var(--accent-soft);color:var(--primary);display:flex;align-items:center;justify-content:center}
.stat .ico .icon{width:18px;height:18px}

/* ---- Listas de posts ---- */
.post-item{display:flex;gap:12px;align-items:center;padding:13px;border:1px solid var(--line);
  border-radius:var(--r);background:var(--surface);margin-bottom:10px;transition:.15s;box-shadow:var(--shadow-sm)}
.post-item:hover{border-color:var(--line-2);transform:translateY(-1px);box-shadow:var(--shadow)}
.post-item .thumb{width:46px;height:46px;border-radius:11px;background:var(--accent-soft);color:var(--primary);
  flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.post-item .thumb .icon{width:22px;height:22px}
.post-item .meta{min-width:0;flex:1}
.post-item .meta .t{color:var(--heading);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-item .meta .s{font-size:12.5px;color:var(--muted)}

/* ---- Flash ---- */
.flash{padding:13px 16px;border-radius:var(--r);margin-bottom:14px;font-size:14px;display:flex;gap:9px;align-items:center;font-weight:500}
.flash-success{background:var(--ok-soft);border:1px solid rgba(46,204,113,.4);color:#7fe7ab}
.flash-error{background:var(--danger-soft);border:1px solid rgba(255,90,77,.4);color:#ff9087}
.flash-info{background:var(--info-soft);border:1px solid rgba(74,163,255,.4);color:#8fc4ff}

/* ---- Tabs ---- */
.tabs{display:flex;gap:4px;overflow-x:auto;border-bottom:1px solid var(--line);margin-bottom:18px;-webkit-overflow-scrolling:touch}
.tabs a{padding:11px 14px;color:var(--muted);font-weight:600;font-size:14px;white-space:nowrap;border-bottom:2px solid transparent;display:flex;align-items:center;gap:7px}
.tabs a.active{color:var(--heading);border-bottom-color:var(--primary)}

/* ---- Tabela ---- */
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);font-size:14px}
.table th{color:var(--muted);font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.5px}
.table tr:last-child td{border-bottom:0}

/* page header */
.page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.page-head h1{margin:0}

.empty{text-align:center;padding:44px 20px;color:var(--muted)}
.empty .ico{width:56px;height:56px;margin:0 auto 12px;border-radius:16px;background:var(--accent-soft);
  color:var(--primary);display:flex;align-items:center;justify-content:center}
.empty .ico .icon{width:28px;height:28px}

/* checkbox */
input[type=checkbox]{width:auto;accent-color:var(--primary)}

/* ---- Kanban ---- */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:12px;-webkit-overflow-scrolling:touch}
.kcol{flex:0 0 280px;max-width:280px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-lg);display:flex;flex-direction:column;max-height:calc(100vh - 200px)}
.kcol__head{display:flex;align-items:center;gap:8px;padding:13px 14px;border-bottom:1px solid var(--line)}
.kcol__dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.kcol__title{font-weight:700;color:var(--heading);font-size:14px}
.kcol__count{margin-left:auto;background:rgba(255,255,255,.08);color:var(--muted);border-radius:999px;padding:2px 9px;font-size:12px;font-weight:700}
.kcol__body{padding:10px;overflow-y:auto;flex:1;min-height:60px}
.kcol.dragover{outline:2px dashed var(--primary);outline-offset:-4px}
.kcard{background:var(--surface);border:1px solid var(--line-2);border-radius:12px;padding:12px;margin-bottom:10px;cursor:grab;box-shadow:var(--shadow-sm);transition:.12s;display:block}
.kcard:hover{box-shadow:var(--shadow);border-color:var(--primary)}
.kcard.dragging{opacity:.5}
.kcard__type{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;display:inline-block;margin-bottom:7px}
.kcard__title{font-weight:700;color:var(--heading);font-size:14px;line-height:1.3;margin-bottom:8px}
.kcard__meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted);flex-wrap:wrap}
.kcard__av{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.kcard__due{display:flex;align-items:center;gap:4px}
.kcard__due.late{color:var(--danger);font-weight:700}
.kcard__chips{display:flex;gap:8px;align-items:center;color:var(--muted-2)}
.kcard__chips span{display:flex;align-items:center;gap:3px;font-size:12px}
.kcard__chips .icon{width:14px;height:14px}

/* ---- Comentários ---- */
.comment{display:flex;gap:10px;margin-bottom:14px}
.comment__av{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:0 0 auto}
.comment__body{flex:1;min-width:0;background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.comment__head{display:flex;gap:8px;align-items:baseline;margin-bottom:3px}
.comment__head strong{color:var(--heading);font-size:14px}
.comment__text{font-size:14px;line-height:1.5}
.comment__text .mention{color:var(--primary);font-weight:700;background:var(--accent-soft);padding:0 4px;border-radius:5px}

/* ---- Menu de @menção ---- */
.mention-menu{position:absolute;z-index:60;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;
  box-shadow:var(--shadow-lg);padding:6px;max-height:240px;overflow-y:auto;min-width:200px}
.mention-opt{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;cursor:pointer;color:var(--text)}
.mention-opt.active,.mention-opt:hover{background:var(--accent-soft)}
.mention-opt strong{color:var(--heading);font-size:14px;font-weight:600}
.mention-opt small{color:var(--muted)}
.mention-av{width:26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex:0 0 auto}

/* ---- Anotação de imagem ---- */
.annot-stage{cursor:crosshair}
.annot-pin{position:absolute;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.5);cursor:pointer}
.annot-pin.resolved{background:var(--ok)}
.annot-list{margin-top:10px;display:flex;flex-direction:column;gap:6px}
.annot-item{display:flex;gap:8px;align-items:center;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:13px}
.annot-item.resolved{opacity:.55;text-decoration:line-through}
.annot-item .annot-num{width:20px;height:20px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex:0 0 auto}
.annot-item.resolved .annot-num{background:var(--ok)}
.annot-item .annot-body{flex:1;min-width:0}
.annot-popup{position:absolute;z-index:50;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;box-shadow:var(--shadow-lg);padding:10px;width:240px}
.annot-popup textarea{min-height:60px;margin-bottom:8px}

/* ---- Modal ---- */
.modal[hidden]{display:none}
.modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:16px}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(2px)}
.modal__card{position:relative;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);
  width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}
.modal__head h3{display:flex;align-items:center;gap:8px}
.modal__x{background:transparent;border:0;color:var(--muted);font-size:26px;line-height:1;cursor:pointer;padding:0 4px}
.modal__x:hover{color:var(--heading)}
.modal__body{padding:18px;overflow-y:auto}
.modal__foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 18px;border-top:1px solid var(--line)}

/* formatos no modal */
.fmt-grid{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.fmt-btn{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--bg-soft);
  border:1px solid var(--line-2);border-radius:12px;padding:12px 14px;cursor:pointer;color:var(--text);min-width:96px;transition:.15s}
.fmt-btn:hover{border-color:var(--primary)}
.fmt-btn.active{border-color:var(--primary);background:var(--accent-soft)}
.fmt-btn strong{font-size:13px;color:var(--heading)}
.fmt-btn small{color:var(--muted);font-size:11px}
.fmt-shape{display:block;background:var(--primary);border-radius:3px;opacity:.85}
.fmt-shape.quadrado{width:26px;height:26px}
.fmt-shape.retrato{width:20px;height:28px}
.fmt-shape.paisagem{width:30px;height:18px}

/* segmento de modo (única / carrossel) */
.seg{display:inline-flex;gap:0;border:1px solid var(--line-2);border-radius:10px;overflow:hidden;margin-top:6px}
.seg-btn{background:var(--bg-soft);color:var(--muted);border:0;padding:9px 16px;cursor:pointer;font-size:13px;font-weight:600;transition:.15s}
.seg-btn+.seg-btn{border-left:1px solid var(--line-2)}
.seg-btn:hover{color:var(--text)}
.seg-btn.active{background:var(--accent-soft);color:var(--heading)}

/* galeria de imagens geradas, por formato */
.img-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.img-fmt-card{background:var(--bg-soft);border:1px solid var(--line-2);border-radius:12px;padding:12px;min-width:0;overflow:hidden}
.img-fmt-head{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.img-fmt-head strong{font-size:13px;color:var(--heading)}
.img-fmt-head small{color:var(--muted);font-size:11px}
.img-fmt-actions{margin-left:auto;display:flex;flex-wrap:wrap;gap:6px}
.img-fmt-actions .btn-sm{white-space:nowrap}
.img-fmt-body{display:flex;flex-wrap:wrap;gap:10px}
.img-empty{font-size:12px}
.img-thumb{position:relative;width:100%;border-radius:10px;overflow:hidden;border:1px solid var(--line-2)}
.img-thumb img{display:block;width:100%;border-radius:10px 10px 0 0}
.img-thumb__x{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:6px;border:0;
  background:rgba(0,0,0,.6);color:#fff;font-size:16px;line-height:1;cursor:pointer}
.img-thumb__x:hover{background:var(--danger,#d33)}
.img-thumb__use{display:flex;align-items:center;gap:6px;padding:7px 8px;font-size:12px;color:var(--text);background:var(--surface);cursor:pointer}
.img-thumb__use input{width:auto}
/* imagem de referência (base) */
.ref-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
#img_refUrlRow{display:flex;gap:6px;margin-top:8px}
#img_refUrlRow[hidden]{display:none}
#img_refUrlRow input{flex:1;min-width:0}
.ref-preview{position:relative;display:inline-block;margin-top:10px}
.ref-preview[hidden]{display:none}
.ref-preview img{display:block;max-width:110px;max-height:110px;border-radius:10px;border:1px solid var(--line-2)}
.ref-preview .img-thumb__x{top:6px;right:6px}
/* carrossel dentro do card de formato */
.carousel-group{width:100%;border:1px dashed var(--line-2);border-radius:10px;padding:8px}
.carousel-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.carousel-head strong{font-size:12px;color:var(--heading)}
.carousel-head .img-thumb__x{position:static;margin-left:auto}
.carousel-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}
.carousel-slide{position:relative;flex:0 0 auto;width:84px}
.carousel-slide img{display:block;width:84px;height:84px;object-fit:cover;border-radius:8px;border:1px solid var(--line-2)}
.carousel-slide .slide-num{position:absolute;top:3px;left:3px;background:var(--primary);color:#fff;font-size:10px;
  font-weight:700;border-radius:5px;padding:1px 5px}

/* área de geração ao vivo (slots grandes + esqueleto + progresso) */
.gen-live{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}
.gen-slot{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line-2);
  background:var(--bg-soft);aspect-ratio:1/1}
.gen-slot img{display:block;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s ease}
.gen-slot.done img{opacity:1}
.gen-slot .slide-num{position:absolute;top:6px;left:6px;z-index:3;background:var(--primary);color:#fff;font-size:11px;
  font-weight:700;border-radius:6px;padding:2px 7px}
.gen-skeleton{position:absolute;inset:0;z-index:1;
  background:linear-gradient(110deg,#1f1f21 8%,#2e2e31 18%,#1f1f21 33%);background-size:200% 100%;
  animation:gen-shimmer 1.25s linear infinite}
.gen-slot.done .gen-skeleton{display:none}
@keyframes gen-shimmer{to{background-position:-200% 0}}
.gen-pct{position:absolute;z-index:2;top:50%;left:0;right:0;transform:translateY(-50%);text-align:center;
  color:#fff;font-weight:800;font-size:20px;letter-spacing:.02em;text-shadow:0 1px 6px rgba(0,0,0,.6)}
.gen-slot.done .gen-pct{display:none}
.gen-progress{position:absolute;z-index:2;left:0;right:0;bottom:0;height:6px;background:rgba(0,0,0,.45)}
.gen-progress__bar{height:100%;width:0;background:var(--primary);transition:width .3s ease}
.gen-slot.done .gen-progress{opacity:0;transition:opacity .4s ease}
.gen-slot.error{border-color:var(--danger,#d33)}
.gen-slot.error .gen-skeleton{animation:none;background:rgba(211,51,51,.12)}
.gen-slot.error .gen-pct{font-size:13px;color:#ff9b9b}

/* lightbox de pré-visualização */
.preview-box{position:relative;display:flex;align-items:center;justify-content:center;max-width:92vw}
#previewImg{max-width:92vw;max-height:82vh;object-fit:contain;border-radius:12px;box-shadow:var(--shadow-lg)}
.preview-close{position:absolute;top:-6px;right:-6px;z-index:2;width:36px;height:36px;border-radius:50%;
  border:0;background:rgba(0,0,0,.7);color:#fff;font-size:22px;line-height:1;cursor:pointer}
.preview-close:hover{background:var(--primary)}
.preview-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  border:0;background:rgba(0,0,0,.55);color:#fff;font-size:28px;line-height:1;cursor:pointer;z-index:2;transition:.15s}
.preview-nav:hover{background:var(--primary)}
.preview-nav.prev{left:-58px}
.preview-nav.next{right:-58px}
.preview-count{position:absolute;bottom:-30px;left:0;right:0;text-align:center;color:#fff;font-size:13px;font-weight:600}
@media (max-width:640px){
  .preview-nav.prev{left:6px}
  .preview-nav.next{right:6px}
  .preview-nav{background:rgba(0,0,0,.7)}
}

/* ---- Posicionador de logo (preview do cliente) ---- */
.logo-stage{position:relative;width:100%;max-width:380px;aspect-ratio:1/1;border-radius:14px;overflow:hidden;
  border:1px solid var(--line-2);user-select:none;touch-action:none;
  background:linear-gradient(135deg,#2a2a2d,#161617),
    repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 12px,transparent 12px 24px)}
.logo-stage::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 70% 20%,rgba(255,102,0,.18),transparent 55%)}
.logo-stage__hint{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);text-align:center;color:var(--muted-2);font-size:12px;padding:0 16px;z-index:1}
.logo-stage img{position:absolute;left:0;top:0;cursor:grab;z-index:2;pointer-events:auto}
.logo-stage img:active{cursor:grabbing}
.logo-handle{position:absolute;width:18px;height:18px;border-radius:4px;background:var(--primary);border:2px solid #fff;
  z-index:3;cursor:nwse-resize;box-shadow:0 2px 6px rgba(0,0,0,.5);display:none}
.logo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-top:6px}
.logo-grid .logo-stage{max-width:100%}
.logo-fmt__label{font-size:12.5px;font-weight:600;color:var(--text);margin-bottom:6px;display:flex;justify-content:space-between;align-items:baseline}
.logo-fmt__label small{color:var(--muted-2);font-weight:500}

/* utilidades */
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:16px}
.text-c{text-align:center}.w-full{width:100%}.hide{display:none}

/* ============ Desktop ============ */
@media (min-width:880px){
  .sidebar{display:flex;flex-direction:column;width:var(--sidebar-w);flex:0 0 var(--sidebar-w);
    background:var(--sidebar);color:#cfcfd6;position:sticky;top:0;height:100vh;padding:20px 14px;border-right:1px solid var(--line)}
  .sidebar .brand{font-weight:800;color:#fff;font-size:20px;padding:6px 12px 20px;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}
  .sidebar .brand b{color:var(--primary)}
  .sidebar nav a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:11px;
    color:#9a9aa4;font-weight:600;font-size:14px;margin-bottom:3px;transition:.15s}
  .sidebar nav a .icon{width:19px;height:19px}
  .sidebar nav a:hover{background:rgba(255,255,255,.06);color:#fff}
  .sidebar nav a.active{background:var(--primary);color:#fff;box-shadow:0 6px 16px rgba(255,102,0,.4)}
  .sidebar .sep{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:#5f5f69;padding:18px 13px 7px;font-weight:700}
  .sidebar .side-foot{margin-top:auto;padding:8px}
  .bottomnav{display:none}
  .content{padding:26px 30px 44px}
  .grid-2{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .stats{grid-template-columns:repeat(4,1fr)}
  h1{font-size:28px}
  .topbar .only-mobile{display:none}
  .topbar{background:rgba(22,22,23,.82)}
}
