/* ============================================================
   Canvas de Projeto
   Estilos: moldura do canvas (escala de cinza, fiel ao PDF)
   e cards (post-its) coloridos no estilo Trello.
   ============================================================ */

:root{
  --ink:#1a1a1a;
  --frame:#000;
  --hint:#6b6b6b;
  --bg:#e9eaec;
  --paper:#ffffff;
  --radius:7px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  height:100vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

/* ---------- Barra de ferramentas ---------- */
.toolbar{
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
  padding:10px 18px 4px;
  background:transparent;
  color:#2b2f36;
  flex:none;z-index:50;
}
.toolbar h1{
  display:flex;align-items:center;gap:8px;
  font-size:15px;margin:0;font-weight:600;letter-spacing:.2px;
}
.brand-ico{display:inline-flex;}
.brand-ico svg{width:20px;height:20px;}
.brand-tag{
  font-size:11px;font-weight:700;
  background:#2b2f36;color:#fff;
  padding:2px 8px;border-radius:999px;
}
.toolbar .spacer{flex:1;}

.btn{
  font:inherit;font-size:13px;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
  background:#ffffff;color:#3a3f47;
  border:1px solid #d3d6db;
  padding:7px 15px;border-radius:999px;
  transition:background .15s,border-color .15s,box-shadow .15s,transform .05s;
}
.btn:hover{
  background:#f6f7f9;border-color:#b6bbc3;
  box-shadow:0 1px 4px rgba(0,0,0,.08);
}
.btn:active{transform:translateY(1px);}
.btn .ico{display:inline-flex;}
.btn .ico svg{width:15px;height:15px;}
.btn.danger{color:#b23b3b;border-color:#e7c4c4;}
.btn.danger:hover{background:#fbeded;border-color:#d99a9a;}
.btn.primary{background:#2b2f36;color:#fff;border-color:#2b2f36;}
.btn.primary:hover{background:#3a4049;border-color:#3a4049;}

/* ---------- Moldura do canvas ---------- */
.canvas-scroll{flex:1;overflow:auto;padding:6px 14px 14px;
  display:flex;flex-direction:column;}
.canvas{
  background:var(--paper);
  /* flex:1 + min-height:0 dá ao canvas uma altura DEFINIDA (= área de
     rolagem). Sem isso a grade cresceria com o conteúdo e o
     minmax(0,1fr) das linhas não limitaria os blocos. */
  width:100%;flex:1;min-height:0;margin:0 auto;
  padding:14px 16px 8px;
  border:1px solid #cfcfcf;
  box-shadow:0 6px 24px rgba(0,0,0,.12);
  display:flex;
  flex-direction:column;
}

/* ---------- Cabeçalho ---------- */
.canvas-header{
  display:grid;
  grid-template-columns:2.8fr 3fr;   /* alinha com col1+col2 e col3+col4+col5 */
  gap:24px;
  margin-bottom:12px;
}
.hdr{display:flex;align-items:baseline;gap:10px;}
.hdr-label{
  font-weight:700;font-size:15px;letter-spacing:.5px;white-space:nowrap;
}
.hdr-label em{font-weight:400;font-style:normal;font-size:12px;color:var(--hint);}
.hdr-field{
  flex:1;min-width:0;border-bottom:2px solid #000;
  padding:2px 4px;min-height:24px;font-size:14px;font-weight:700;outline:none;
}
.hdr-field:focus{background:#fafad8;}
.hdr-field:empty::before{content:attr(data-ph);color:#bdbdbd;font-weight:400;}

/* ---------- Corpo: 2 metades empilhadas (top/bottom) ----------
   A grade visual fiel ao PDF é construída em 2 níveis:
     canvas-body  -> flex coluna com 2 metades de altura igual
     .half        -> grade 2 colunas (1.25fr esquerda | 4.55fr direita)
   Os grupos da direita (g3/g4) são grades de 4 colunas internas
   (1.55fr 1fr 1fr 1fr) — mesmas proporções da grade original. */
.canvas-body{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  gap:9px;
}
.half{
  flex:1 1 0;
  min-height:0;
  display:grid;
  grid-template-columns:1.25fr 4.55fr;
  /* minmax(0,1fr): a linha não cresce com o conteúdo, mantendo a
     altura limitada à metade do canvas e permitindo rolagem interna. */
  grid-template-rows:minmax(0,1fr);
  gap:9px;
}
.group{min-height:0;}
.group-1, .group-2{
  display:flex;
  flex-direction:column;
  gap:9px;
}
.group-3, .group-4{
  display:grid;
  grid-template-columns:1.55fr 1fr 1fr 1fr;
  grid-template-rows:minmax(0,1fr);
  gap:9px;
}
.escopo-stack{
  display:flex;
  flex-direction:column;
  gap:9px;
  min-height:0;
}

/* ---------- Bloco ---------- */
.block{
  display:flex;flex-direction:column;
  border:2px solid var(--frame);
  border-radius:var(--radius);
  background:#fff;
  min-height:0;
  /* overflow visível para a tooltip de ajuda não ser recortada */
  overflow:visible;
}
.block-head{
  display:flex;align-items:flex-start;gap:7px;
  padding:7px 8px 5px;
}
.block-icon{flex:none;display:flex;line-height:0;}
.block-icon svg{width:19px;height:19px;}
.block-title{
  font-weight:700;font-size:12.5px;line-height:1.15;flex:1;
  text-transform:uppercase;
}
/* Tooltip de ajuda (mostrada ao clicar no botão "?"). */
.help-wrap{position:relative;display:inline-flex;align-self:center;}
.block-hint{
  display:none;
  position:absolute;
  top:calc(100% + 8px);
  right:-2px;
  z-index:40;
  width:230px;max-width:68vw;
  font-weight:400;text-transform:none;
  font-size:11px;line-height:1.45;
  color:#fff;background:#2b2f36;
  padding:8px 11px;
  border-radius:8px;
  box-shadow:0 8px 22px rgba(0,0,0,.28);
}
.block-hint::before{
  content:"";
  position:absolute;
  top:-5px;right:7px;
  border:5px solid transparent;
  border-top:0;
  border-bottom-color:#2b2f36;
}
.block.show-hint .block-hint{display:block;}
.block-count{
  flex:none;font-size:10px;color:#888;font-weight:700;
  background:#f0f0f0;border-radius:10px;padding:1px 7px;align-self:center;
}
/* Botão de ajuda: cinza claro neutro. */
.help-btn{
  flex:none;cursor:pointer;align-self:center;
  width:20px;height:20px;border-radius:50%;
  border:1px solid #d4d4d4;background:#f2f2f2;color:#555;
  font-size:12px;font-weight:700;line-height:1;
}
.help-btn:hover,
.help-btn.active{background:#555;color:#fff;border-color:#555;}

/* Botão de adicionar: cinza mais escuro que o de ajuda. */
.add-btn{
  flex:none;cursor:pointer;border:1px solid #b8b8b8;background:#d6d6d6;
  width:22px;height:22px;border-radius:5px;font-size:16px;line-height:1;
  color:#333;align-self:center;
}
.add-btn:hover{background:#2b2f36;color:#fff;border-color:#2b2f36;}
.block-body{
  flex:1 1 auto;
  padding:5px 7px 8px;
  display:flex;flex-direction:column;gap:6px;
  min-height:46px;
  overflow-y:auto;
  /* Barra de rolagem fina (Firefox) */
  scrollbar-width:thin;
  scrollbar-color:#b6b6b6 transparent;
}
/* Barra de rolagem fina (Chrome, Edge, Safari) */
.block-body::-webkit-scrollbar{width:6px;}
.block-body::-webkit-scrollbar-track{background:transparent;}
.block-body::-webkit-scrollbar-thumb{
  background:#c2c2c2;
  border-radius:3px;
}
.block-body::-webkit-scrollbar-thumb:hover{background:#9a9a9a;}
.block-body.drop-hover{
  background:#eef6ff;
  outline:2px dashed #6aa9e0;outline-offset:-4px;
}

/* ---------- Card (post-it) ---------- */
.card{
  position:relative;
  border-radius:4px;
  padding:7px 9px;
  font-size:12px;line-height:1.35;
  box-shadow:0 1px 2px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.06);
  cursor:grab;
  word-break:break-word;
  white-space:pre-wrap;
}
.card:active{cursor:grabbing;}
.card.dragging{opacity:.4;}
.card.editing{cursor:text;box-shadow:0 0 0 2px #3d7fd1;}
.card-text{outline:none;min-height:16px;}
.card-text:empty::before{content:'Escreva aqui…';color:#9a9a86;}

.card-tools{
  position:absolute;top:-10px;right:6px;
  display:flex;gap:3px;align-items:center;
  background:#fff;border:1px solid #ddd;border-radius:12px;
  padding:2px 5px;box-shadow:0 1px 3px rgba(0,0,0,.22);
  opacity:0;transition:opacity .12s;
}
.card:hover .card-tools{opacity:1;}
.card.editing .card-tools{opacity:0;pointer-events:none;}
.dot{
  width:13px;height:13px;border-radius:50%;
  border:1px solid rgba(0,0,0,.25);cursor:pointer;padding:0;
}
.dot:hover{transform:scale(1.25);}
.card-del{
  border:none;background:none;cursor:pointer;font-size:16px;
  line-height:1;color:#b23b3b;padding:0 2px;margin-left:2px;
}
.card-del:hover{color:#7a1f1f;}

/* ---------- Rodapé ---------- */
.canvas-footer{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-size:10px;color:#7a7a7a;margin-top:10px;padding-top:6px;
  border-top:1px solid #e2e2e2;
}
.cc-badge{font-weight:700;}

/* ---------- Impressão ---------- */
@media print{
  @page{size:landscape;margin:8mm;}
  body{background:#fff;height:auto;display:block;overflow:visible;}
  .toolbar{display:none!important;}
  /* display:block: na impressão o canvas deixa de ser item flex,
     então o height:100vh volta a ser respeitado (senão ele colapsa). */
  .canvas-scroll{overflow:visible;padding:0;flex:none;display:block;}
  /* display:block + height:auto: containers flex não quebram entre
     páginas no Chrome. Em fluxo de bloco, o canvas cresce e empurra
     as metades para páginas seguintes quando o conteúdo transborda. */
  .canvas{box-shadow:none;border:none;width:100%;max-width:100%;
          display:block;flex:none;height:auto;padding:0;overflow:visible;}
  .canvas-body{display:block;flex:none;min-height:0;}
  /* Cada metade é uma grade de bloco com break-inside:avoid: tenta
     ficar inteira em uma página. min-height ~44vh deixa as duas
     metades + cabeçalho caberem confortavelmente em uma única
     página quando nada transborda. */
  .half{
    display:grid;
    flex:none;
    grid-template-columns:1.25fr 4.55fr;
    grid-template-rows:auto;
    gap:6px;
    min-height:44vh;
    break-inside:avoid;
    page-break-inside:avoid;   /* legado para WebKit/print antigos */
    margin-bottom:6px;
  }
  .half:last-child{margin-bottom:0;}
  /* Modo "2 páginas": só é ativado pelo JS (beforeprint) quando
     algum block-body tem conteúdo além do limite (scrollHeight >
     clientHeight). Cada metade ocupa uma página inteira; a metade
     superior força quebra de página depois de si. */
  body.print-overflow .half{min-height:92vh;}
  body.print-overflow .half-top{
    break-after:page;
    page-break-after:always;
  }
  .group-1, .group-2, .escopo-stack{
    display:flex;
    flex-direction:column;
    gap:6px;
  }
  .group-3, .group-4{
    display:grid;
    grid-template-columns:1.55fr 1fr 1fr 1fr;
    grid-template-rows:auto;
    gap:6px;
  }
  .block{display:flex;flex-direction:column;}
  .block-body{display:flex;flex-direction:column;gap:3px;
              padding:3px 5px 5px;overflow:visible;}
  .add-btn,.help-btn,.card-tools,.block-count,
  .canvas-footer{display:none!important;}
  /* Subtítulos de ajuda nunca saem na impressão, mesmo se abertos na tela. */
  .block-hint{display:none!important;}
  .card{
    box-shadow:none;
    border:1px solid #bbb;
    font-size:10px;
    padding:3px 6px;
    /* Evita que um card seja partido ao meio na quebra de página. */
    break-inside:avoid;
  }
}

/* ---------- Responsivo (telas pequenas) ----------
   Restrito a 'screen': na impressão a grade original é mantida,
   independentemente da largura da página. */
@media screen and (max-width:900px){
  .canvas-scroll{padding:10px;}
  /* Em telas pequenas a grade vira coluna única: o canvas volta a
     crescer com o conteúdo e a página rola normalmente. */
  .canvas{width:100%;flex:none;min-height:100%;}
  .canvas-header{grid-template-columns:1fr;gap:10px;}
  /* Metades e grupos colapsam para uma única coluna empilhada. */
  .half, .group-3, .group-4{
    display:flex;
    flex-direction:column;
    gap:9px;
  }
}
