/* ---- Ninho · visual estilo Notion + identidade Hoa ---- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Manrope:wght@700;800&display=swap');

:root{
  --lime:#d4ff3a;
  --lime-dim:#b9e02f;

  /* conteúdo (claro) */
  --page-bg:#fdfdfb;
  --page-fg:#32302a;
  --surface:#ffffff;
  --surface-2:#f4f2ec;
  --hair:#e9e7de;
  --muted:#98957f;
  --chip:#ece9df;
  --hover-soft:rgba(0,0,0,.035);
  --danger:#e0563f;
  --shadow:0 4px 24px rgba(0,0,0,.07);

  /* sidebar (claro = clara, estilo Notion) */
  --sb-bg:#f6f4ec;
  --sb-fg:#5a574c;
  --sb-strong:#1f1e19;
  --sb-hover:#ebe8dc;
  --sb-active:#e5e1d1;
  --sb-border:#e6e3d6;
}

/* ---- Tema escuro (black) ---- */
html[data-theme="dark"]{
  --page-bg:#191916;
  --page-fg:#e8e6de;
  --surface:#232320;
  --surface-2:#26261f;
  --hair:#34342c;
  --muted:#8f8d7e;
  --chip:#31312a;
  --hover-soft:rgba(255,255,255,.045);
  --shadow:0 6px 28px rgba(0,0,0,.45);

  --sb-bg:#202019;
  --sb-fg:#b6b3a4;
  --sb-strong:#f0eee4;
  --sb-hover:#2b2b23;
  --sb-active:#33332a;
  --sb-border:#2d2d25;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--page-bg);color:var(--page-fg);font-size:15px;line-height:1.55;
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;transition:background .18s,color .18s}
::selection{background:rgba(212,255,58,.45);color:#1a1a17}

/* scrollbars discretas */
*{scrollbar-width:thin;scrollbar-color:var(--chip) transparent}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--chip);border-radius:9px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-track{background:transparent}

/* ---------- Login / instalação ---------- */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:
  radial-gradient(1100px 560px at 85% -10%, rgba(212,255,58,.16), transparent),var(--page-bg)}
.auth-card{background:var(--surface);border:1px solid var(--hair);border-radius:18px;padding:36px;
  width:min(430px,92vw);box-shadow:var(--shadow)}
.auth-card .brand{font-family:'Manrope';font-weight:800;letter-spacing:-.02em;font-size:22px}
.auth-card h1{font-family:'Manrope';font-size:26px;margin:.45em 0 .2em;letter-spacing:-.02em}
.auth-card .muted{color:var(--muted);margin-top:0;font-size:14px}
.auth-card label{display:block;font-weight:600;font-size:13px;margin:14px 0 0;color:var(--page-fg)}
.auth-card input{width:100%;margin-top:6px;padding:11px 12px;border:1px solid var(--hair);border-radius:10px;
  font-size:15px;font-family:inherit;background:var(--surface);color:var(--page-fg);transition:border .12s,box-shadow .12s}
.auth-card input:focus{outline:none;border-color:var(--lime-dim);box-shadow:0 0 0 3px rgba(212,255,58,.28)}
.auth-card fieldset{border:1px solid var(--hair);border-radius:12px;padding:8px 16px 18px;margin:16px 0}
.auth-card legend{font-weight:700;padding:0 6px;font-size:14px}
.btn{display:inline-block;margin-top:20px;background:var(--lime);color:#1a1a17;border:none;border-radius:10px;
  padding:12px 20px;font-weight:700;font-size:15px;font-family:inherit;cursor:pointer;text-decoration:none;
  text-align:center;transition:background .12s,transform .06s}
.btn:hover{background:var(--lime-dim)}
.btn:active{transform:translateY(1px)}
.error{background:#fdeae6;color:var(--danger);border-radius:10px;padding:10px 12px;font-size:14px;margin-top:14px}
.warn{background:#fff8e1;color:#7a5b00;border-radius:10px;padding:10px 12px;font-size:14px}

/* ---------- Layout do app ---------- */
#app{display:flex;height:100vh;overflow:hidden}

.sidebar{width:268px;flex:0 0 268px;background:var(--sb-bg);color:var(--sb-fg);display:flex;flex-direction:column;
  border-right:1px solid var(--sb-border);transition:margin-left .18s ease}
#app.side-hidden .sidebar{margin-left:-268px}
.side-head{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 8px}
.side-head .brand{font-family:'Manrope';font-weight:800;font-size:17px;letter-spacing:-.02em;color:var(--sb-strong)}
.side-head-btns{display:flex;gap:2px}
.icon-btn{background:transparent;border:none;color:var(--sb-fg);font-size:15px;cursor:pointer;opacity:.75;
  padding:3px 7px;border-radius:6px;transition:background .1s}
.icon-btn:hover{opacity:1;background:var(--sb-hover)}

.side-user{display:flex;align-items:center;gap:9px;padding:4px 14px 12px;border-bottom:1px solid var(--sb-border)}
.avatar{width:26px;height:26px;border-radius:8px;background:var(--lime);color:#1a1a17;font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:13px;text-transform:uppercase}
.uname{font-weight:600;font-size:13.5px;flex:1;color:var(--sb-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.logout{color:var(--muted);font-size:12px;text-decoration:none}
.logout:hover{color:var(--sb-strong)}

.side-actions{display:flex;gap:8px;padding:12px 14px 6px}
.new-btn{flex:1;background:transparent;color:var(--sb-fg);border:1px solid var(--sb-border);border-radius:8px;
  padding:7px;font-weight:600;font-size:12.5px;cursor:pointer;font-family:inherit;transition:background .1s,color .1s}
.new-btn:hover{background:var(--sb-hover);color:var(--sb-strong)}

.tree{flex:1;overflow-y:auto;padding:6px 8px 24px}
.tree-item{border-radius:8px}
.tree-row{display:flex;align-items:center;gap:2px;padding:4px 6px;border-radius:7px;cursor:pointer;
  font-size:13.5px;font-weight:500;color:var(--sb-fg);transition:background .08s}
.tree-row:hover{background:var(--sb-hover)}
.tree-row.active{background:var(--sb-active);color:var(--sb-strong)}
.tree-row.active .t-title{font-weight:700}
.caret{width:16px;text-align:center;font-size:9px;opacity:.55;cursor:pointer;flex:0 0 16px;user-select:none;border-radius:4px}
.caret:hover{opacity:1}
.caret.empty{visibility:hidden}
.t-icon{flex:0 0 20px;text-align:center;font-size:15px}
.t-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-left:2px}
.t-add{opacity:0;border:none;background:transparent;color:var(--sb-fg);cursor:pointer;font-size:14px;
  padding:0 5px;border-radius:5px}
.tree-row:hover .t-add{opacity:.85}
.t-add:hover{background:var(--sb-active);opacity:1}
.children{margin-left:15px;border-left:1px solid var(--sb-border);padding-left:2px}

/* ---------- Área principal ---------- */
.main{flex:1;overflow-y:auto}
.view{max-width:800px;margin:0 auto;padding:64px 48px 180px}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:70vh;
  color:var(--muted);text-align:center;font-size:14.5px}
.empty-emoji{font-size:56px;margin-bottom:12px}

.page-head{display:flex;align-items:center;gap:12px;margin-bottom:2px}
.page-icon{font-size:44px;line-height:1;cursor:pointer;background:transparent;border:none;border-radius:10px;padding:2px}
.page-icon:hover{background:var(--hover-soft)}
.page-title{font-family:'Manrope';font-size:40px;font-weight:800;letter-spacing:-.03em;border:none;outline:none;
  width:100%;font-family-fallback:inherit;background:transparent;color:var(--page-fg)}
.page-title::placeholder{color:var(--chip)}
.page-meta{display:flex;gap:14px;align-items:center;margin:4px 0 30px;color:var(--muted);font-size:12.5px}
.page-del{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:12.5px;font-family:inherit;
  padding:3px 8px;border-radius:6px}
.page-del:hover{color:var(--danger);background:var(--hover-soft)}

/* ---------- Blocos ---------- */
.blocks{display:flex;flex-direction:column;gap:1px}
.block{display:flex;align-items:flex-start;gap:4px;border-radius:6px;padding:3px 4px}
.block:hover{background:var(--hover-soft)}
.b-handle{opacity:0;cursor:pointer;color:var(--muted);font-size:13px;padding:3px 2px 0;flex:0 0 16px;
  user-select:none;text-align:center;border-radius:4px;transition:opacity .1s}
.block:hover .b-handle,.toggle-head:hover .b-handle{opacity:.55}
.b-handle:hover{opacity:1 !important;background:var(--hover-soft)}
.b-body{flex:1;min-width:0}
.b-text{outline:none;width:100%;min-height:1.55em;word-break:break-word}
.b-text:empty::before{content:attr(data-ph);color:var(--muted);opacity:.55}
.b-text.h1{font-family:'Manrope';font-size:28px;font-weight:800;letter-spacing:-.02em;margin-top:16px}
.b-text.h2{font-family:'Manrope';font-size:22px;font-weight:800;letter-spacing:-.01em;margin-top:12px}
.b-text.h3{font-size:17.5px;font-weight:700;margin-top:8px}
.b-bullet{list-style:none}
.b-bullet .b-text::before{content:"•";color:var(--page-fg);margin-right:9px;font-size:17px}
.todo-row{display:flex;align-items:flex-start;gap:8px}
.todo-row input[type=checkbox]{margin-top:5px;width:16px;height:16px;accent-color:var(--lime-dim);cursor:pointer}
.todo-row.done .b-text{color:var(--muted);text-decoration:line-through}

.toggle-block{border-radius:8px}
.toggle-head{display:flex;align-items:flex-start;gap:4px;border-radius:6px;padding:2px 4px}
.toggle-head:hover{background:var(--hover-soft)}
.toggle-caret{cursor:pointer;user-select:none;color:var(--muted);font-size:11px;padding:5px 4px 0;
  transition:transform .12s;border-radius:4px}
.toggle-caret:hover{color:var(--page-fg)}
.toggle-block.collapsed .toggle-caret{transform:rotate(-90deg)}
.toggle-children{margin-left:24px;border-left:2px solid var(--hair);padding-left:12px;margin-top:2px;
  display:flex;flex-direction:column;gap:1px}
.toggle-block.collapsed .toggle-children{display:none}

/* menu de bloco (aparece no ⋮⋮ ou digitando "/") */
.block-menu{position:absolute;background:var(--surface);border:1px solid var(--hair);border-radius:12px;
  box-shadow:0 12px 34px rgba(0,0,0,.16);padding:6px;z-index:50;min-width:200px}
.menu-cap{font-size:10.5px;font-weight:700;color:var(--muted);padding:6px 10px 3px;
  text-transform:uppercase;letter-spacing:.05em}
.block-menu button{display:flex;gap:9px;align-items:center;width:100%;text-align:left;background:transparent;
  border:none;padding:7px 10px;border-radius:8px;cursor:pointer;font-size:14px;font-family:inherit;color:var(--page-fg)}
.block-menu button:hover{background:var(--surface-2)}

/* ---------- Kanban ---------- */
.board{display:flex;gap:22px;align-items:flex-start;overflow-x:auto;padding:4px 2px 24px}
.column{background:transparent;border-radius:10px;width:280px;flex:0 0 280px}
.col-head{display:flex;align-items:center;gap:7px;padding:2px 4px 10px}
.col-title{font-weight:700;font-size:14px;border:none;background:transparent;flex:1;font-family:inherit;
  outline:none;color:var(--page-fg)}
.col-count{background:var(--chip);color:var(--muted);border-radius:20px;font-size:11.5px;padding:1px 8px;font-weight:700}
.col-del{border:none;background:transparent;color:var(--muted);cursor:pointer;opacity:0;border-radius:5px}
.column:hover .col-del{opacity:.7}
.col-del:hover{color:var(--danger)}
.cards{display:flex;flex-direction:column;gap:8px;min-height:14px}
.card{background:var(--surface);border:1px solid var(--hair);border-radius:9px;padding:10px 12px;cursor:grab;
  box-shadow:0 1px 3px rgba(0,0,0,.05);transition:box-shadow .12s,transform .12s}
.card:hover{box-shadow:0 4px 14px rgba(0,0,0,.09);transform:translateY(-1px)}
.card.dragging{opacity:.4}
.card.done{opacity:.55}
.card-top{display:flex;align-items:flex-start;gap:8px}
.card input[type=checkbox]{margin-top:3px;accent-color:var(--lime-dim);cursor:pointer}
.card-title{flex:1;font-size:14px;outline:none;word-break:break-word;color:var(--page-fg)}
.card.done .card-title{text-decoration:line-through;color:var(--muted)}
.card-due{display:inline-flex;align-items:center;gap:5px;margin-top:8px;font-size:12px;color:var(--muted);
  cursor:pointer;border-radius:5px;padding:1px 4px}
.card-due:hover{background:var(--hover-soft)}
.card-due.soon{color:#c9821f}
.card-due.late{color:var(--danger);font-weight:700}
.card-due input{border:1px solid var(--hair);border-radius:6px;font-family:inherit;font-size:12px;padding:2px 4px;
  background:var(--surface);color:var(--page-fg)}
.card-x{float:right;border:none;background:transparent;color:var(--muted);cursor:pointer;opacity:0;font-size:13px;border-radius:5px}
.card:hover .card-x{opacity:.6}
.card-x:hover{color:var(--danger)}
.add-card{width:100%;text-align:left;border:none;background:transparent;color:var(--muted);padding:8px 6px;
  border-radius:8px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;margin-top:4px;transition:background .1s}
.add-card:hover{background:var(--hover-soft);color:var(--page-fg)}
.add-col{flex:0 0 210px;border:2px dashed var(--hair);background:transparent;border-radius:12px;color:var(--muted);
  padding:13px;cursor:pointer;font-family:inherit;font-weight:600;font-size:13.5px;transition:border-color .12s,color .12s}
.add-col:hover{border-color:var(--muted);color:var(--page-fg)}
.cards.drop-hint{background:rgba(212,255,58,.10);outline:2px dashed var(--lime-dim);outline-offset:4px;border-radius:10px}

/* pill "salvando…" */
.saving{position:fixed;bottom:16px;right:18px;background:var(--surface);color:var(--page-fg);font-size:12px;
  padding:6px 13px;border-radius:20px;border:1px solid var(--hair);box-shadow:var(--shadow);
  opacity:0;transition:opacity .2s;pointer-events:none}
.saving.show{opacity:.95}

/* botão de reabrir o menu (mobile + sidebar recolhida no desktop) */
.side-open{display:none;position:fixed;top:12px;left:12px;z-index:40;background:var(--surface);color:var(--page-fg);
  border:1px solid var(--hair);width:38px;height:38px;border-radius:10px;font-size:16px;cursor:pointer;box-shadow:var(--shadow)}
#app.side-hidden ~ .side-open{display:block}

@media(max-width:760px){
  .sidebar{position:fixed;z-index:60;height:100%;box-shadow:var(--shadow)}
  #app:not(.side-open-m) .sidebar{margin-left:-268px}
  .side-open{display:block}
  .view{padding:66px 22px 150px}
  .page-title{font-size:30px}
  .page-icon{font-size:34px}
}
