/* Master stylesheet — imports CSS modules na ordem original do cascade.
   Ao editar, vá direto no arquivo do módulo (Assets/Style/css/modules/).
   Vite inlinea os @imports no build. */

/* ── TOKENS ── */

:root {
  --font-sans:'Inter',sans-serif;

  /* Superfícies */
  --bg:#1a1a1a; --bg2:#22242b; --surface:#202020; --surface2:#282828; --surface3:#303030;
  --border:rgba(255,255,255,0.07); --border2:rgba(255,255,255,0.12);

  /* Texto */
  --text:#dcddde; --text2:#8b8b8b; --text3:#555555; --text-on-accent:#fff;

  /* Acento (roxo) */
  --accent:#7c6aff; --accent2:#a594ff;
  --accent-soft:rgba(124,106,255,0.10); --accent-glow:rgba(124,106,255,0.18);
  --accent-strong:rgba(124,106,255,0.30); --accent-edge:rgba(124,106,255,0.45);

  /* Semânticas de status */
  --green:#22c97e; --green-soft:rgba(34,201,126,0.10);
  --amber:#f5a623; --amber-soft:rgba(245,166,35,0.10);
  --red:#ff5e5e; --red-soft:rgba(255,94,94,0.10);
  --blue:#4fa3ff; --blue-soft:rgba(79,163,255,0.10);

  /* Gradientes */
  --gradient-cover:var(--gradient-cover);

  /* Sombras */
  --shadow-sm:0 2px 8px rgba(0,0,0,0.18);
  --shadow-md:0 4px 16px rgba(0,0,0,0.30);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.45);

  /* Overlays */
  --overlay-white-05:rgba(255,255,255,0.05);
  --overlay-white-08:rgba(255,255,255,0.08);
  --overlay-black-30:rgba(0,0,0,0.30);
  --overlay-black-45:rgba(0,0,0,0.45);

  /* Callouts e diversos */
  --callout-bg:#fff9db;

  /* Layout */
  --radius:6px; --radius-sm:4px; --sw:52px;
}

*{box-sizing:border-box;margin:0;padding:0;}

body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;overflow:hidden;}

/* Fonte global do sistema */

body,button,input,select,textarea,[contenteditable],.btn,.page-title,.modal-title,.stat-val,.cal-month,.alarm-time,.kbv-title,.ne-title,.tut-public-title,.shop-total-val,.media-stat-val,.fin-summary-val,.fin-item-val,.fin-salary-inp,.time-display{
  font-family:var(--font-sans) !important;
}

/* Preservar tipografia de código/monospace */

pre,code,kbd,samp,.bcode,.bcode-edit,.kbv-code,.pilula-exemplo-code,.dbd-slim-name,.dbd-sch-name b,.dbd-sch-type code,.dbd-rules-inline,.music-time,.b-block-label,.kb-slash-icon,.b-type-btn{
  font-family:'DM Mono',monospace !important;
}

/* ── SIDEBAR ── */

.sidebar{width:var(--sw);min-width:var(--sw);background:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;position:fixed;left:0;top:0;z-index:10;}

.logo{height:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}

.logo span{display:none;}

.nav-group{padding:6px 0;flex:1;overflow-y:auto;overflow-x:hidden;}

.nav-section{display:none;}

.nav-item{display:flex;align-items:center;justify-content:center;gap:0;padding:0;height:40px;border-radius:0;cursor:pointer;font-size:0;color:var(--text3);transition:color .12s,background .12s;margin-bottom:0;border:none;border-left:2px solid transparent;background:none;width:100%;position:relative;}

.nav-item:hover{background:var(--surface2);color:var(--text2);}

.nav-item.active{background:rgba(124,106,255,0.08);color:var(--accent2);border-left-color:var(--accent);}

.nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;}

.nav-icon svg{width:18px;height:18px;}

.nav-item .badge{position:absolute;top:5px;right:5px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;border-radius:99px;padding:1px 4px;min-width:14px;text-align:center;}

/* note nav items hidden in icon rail */

.note-nav-item{display:none;}

.sidebar-footer{padding:8px 0;border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;}

.time-display,.date-display{display:none;}

/* contas flutuante (lado direito) */

.account-float-panel{
  position:fixed;
  right:14px;
  top:50px;
  width:110px;
  height:calc(100vh - 64px);
  max-height:calc(100vh - 64px);
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:14px;
  padding:10px 8px 8px;
  z-index:40;
  display:flex;
  flex-direction:column;
  gap:8px;
  transition:right .2s ease, opacity .2s ease, height .2s ease;
}

.account-float-panel.collapsed{right:-132px;opacity:.2;pointer-events:none;}

.account-float-collapse{
  position:absolute;left:-18px;top:12px;
  width:18px;height:28px;border:none;border-radius:8px 0 0 8px;
  background:var(--surface2);color:var(--text2);cursor:pointer;
}

.account-float-list{overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-right:2px;}

.account-float-card{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;}

.account-float-avatar{
  width:46px;height:46px;border-radius:50%;
  border:2px solid var(--border2);
  background:linear-gradient(135deg, var(--surface3), var(--surface2));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:18px;font-weight:700;position:relative;overflow:hidden;
}

.account-float-avatar img{width:100%;height:100%;object-fit:cover;}

.account-float-status{
  position:absolute;right:-1px;top:-1px;width:12px;height:12px;border-radius:50%;
  border:2px solid var(--surface);background:var(--green);
}

.account-float-status.offline{background:var(--text3);}

.account-float-name{
  width:100%;background:var(--accent-soft);color:var(--accent2);border:1px solid rgba(124,106,255,.3);border-radius:4px;
  font-size:11px;font-weight:700;line-height:1;padding:4px 4px;text-align:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.account-float-desc{
  width:100%;font-size:9px;color:var(--text3);text-align:center;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.account-float-card.active .account-float-avatar{border-color:var(--accent2);box-shadow:0 0 0 2px rgba(124,106,255,.2);}

.account-float-card.active .account-float-name{background:var(--accent);color:#fff;border-color:var(--accent);}

.account-float-foot{display:flex;justify-content:center;}

.account-float-add{
  width:28px;height:28px;border:1px dashed var(--border2);border-radius:50%;
  background:transparent;color:var(--text2);cursor:pointer;font-size:18px;line-height:1;
}

.account-float-open{
  position:fixed;right:0;top:calc(50% + 20px);transform:translateY(-50%);
  width:20px;height:34px;border:none;border-radius:8px 0 0 8px;
  background:var(--surface2);color:var(--text2);cursor:pointer;z-index:40;
}

@media (max-width: 980px){
  .account-float-panel,.account-float-open{display:none !important;}
}

/* ── NOTES TREE PANEL ── */

:root{ --nbw:260px; }

.nb-panel{
  position:fixed;left:var(--sw);top:0;
  width:var(--nbw);height:100vh;
  background:var(--bg);border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  z-index:9;
  transform:translateX(calc(-1 * var(--nbw) - 1px));
  transition:transform .22s cubic-bezier(.4,0,.2,1);
  user-select:none;
}

.nb-panel.open{transform:translateX(0);}

.nb-panel-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 10px 0 14px;height:44px;
  border-bottom:1px solid var(--border);flex-shrink:0;
}

.nb-panel-title{font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;}

.nb-panel-close{
  width:22px;height:22px;display:flex;align-items:center;justify-content:center;
  background:none;border:none;color:var(--text3);cursor:pointer;
  border-radius:var(--radius-sm);transition:color .12s,background .12s;padding:0;
}

.nb-panel-close:hover{background:var(--surface2);color:var(--text);}

.nb-panel-close svg{width:14px;height:14px;}

.nb-panel-body{flex:1;overflow-y:auto;padding:6px 0;}

.nb-panel-footer{
  padding:8px 10px;border-top:1px solid var(--border);flex-shrink:0;
}

.nb-panel-add{
  width:100%;display:flex;align-items:center;gap:7px;
  padding:6px 8px;background:none;border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text3);cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:12px;transition:all .12s;
}

.nb-panel-add:hover{background:var(--surface2);color:var(--text);border-color:var(--border2);}

.nb-panel-add svg{width:13px;height:13px;flex-shrink:0;}

/* Group */

.nb-group{margin-bottom:2px;}

.nb-group-hdr{
  display:flex;align-items:center;gap:5px;
  padding:4px 10px 4px 8px;cursor:pointer;
  font-size:11px;font-weight:600;color:var(--text3);
  letter-spacing:.06em;text-transform:uppercase;
  transition:color .12s;
}

.nb-group-hdr:hover{color:var(--text2);}

.nb-chevron{width:12px;height:12px;flex-shrink:0;transition:transform .15s;color:var(--text3);}

.nb-group.collapsed .nb-chevron{transform:rotate(-90deg);}

.nb-group-count{
  margin-left:auto;font-size:10px;font-weight:500;
  color:var(--text3);background:var(--surface2);
  border-radius:99px;padding:1px 6px;
}

.nb-group-items{overflow:hidden;}

.nb-group.collapsed .nb-group-items{display:none;}

/* Tree item */

.nb-item{
  display:flex;align-items:center;gap:7px;
  padding:4px 10px 4px 22px;cursor:pointer;
  font-size:13px;color:var(--text2);
  border-left:2px solid transparent;
  transition:color .1s,background .1s;position:relative;
}

.nb-item:hover{background:var(--surface2);color:var(--text);}

.nb-item.active{background:rgba(124,106,255,0.08);color:var(--accent2);border-left-color:var(--accent);}

.nb-item-icon{font-size:13px;flex-shrink:0;line-height:1;}

.nb-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;}

.nb-file-item{padding:3px 10px 3px 14px;gap:0;}

.nb-item-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;color:var(--text2);}

.nb-item.active .nb-item-name{color:var(--accent2);}

.nb-item:hover .nb-item-name{color:var(--text);}

.nb-item-filetype{font-size:10px;color:var(--text3);letter-spacing:.05em;text-transform:uppercase;flex-shrink:0;margin-left:8px;}

.nb-empty{padding:20px 14px;font-size:12px;color:var(--text3);}

.nb-mat-hdr{display:flex;align-items:center;gap:6px;padding:3px 10px 3px 8px;cursor:pointer;color:var(--text2);font-size:13px;transition:color .1s,background .1s;}

.nb-mat-hdr:hover{background:var(--surface2);color:var(--text);}

.nb-mat.collapsed .nb-mat-hdr .nb-chevron{transform:rotate(-90deg);}

.nb-mat.collapsed .nb-mat-body{display:none;}

.nb-mat-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.nb-mat-count{font-size:10px;color:var(--text3);flex-shrink:0;}

.nb-sub-item{padding-left:28px !important;}

.nb-sub-empty{padding:4px 14px 4px 28px;font-size:11px;color:var(--text3);}

/* ── TOPBAR ── */

.nb-topbar{
  position:fixed;top:0;
  left:var(--sw);right:0;
  height:46px;z-index:8;
  display:flex;align-items:center;
  padding:0 10px;gap:10px;
  background:linear-gradient(180deg,#2b2d31 0%, #26282d 100%);
  border-bottom:none;
  box-shadow:inset 0 -1px 0 rgba(255,255,255,0.03);
  transition:left .22s cubic-bezier(.4,0,.2,1), right .22s cubic-bezier(.4,0,.2,1);
}

body.nb-open .nb-topbar{left:calc(var(--sw) + var(--nbw));}

.nb-top-btn{
  width:30px;height:30px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.08);
  border-radius:8px;
  color:var(--text3);cursor:pointer;
  transition:color .12s,background .12s;flex-shrink:0;
}

.nb-top-btn svg{width:16px;height:16px;}

.nb-top-btn:hover{background:rgba(255,255,255,0.06);color:var(--text);}

.nb-top-btn.open{color:var(--accent2);}

/* Main shifts when panel open + topbar offset */

body.nb-open .main{margin-left:calc(var(--sw) + var(--nbw));}

.main{padding-top:44px;}

.main{padding-top:46px;}

/* ── MAIN ── */

.main{margin-left:var(--sw);flex:1;height:100vh;overflow-y:auto;transition:margin-left .22s cubic-bezier(.4,0,.2,1);}

.hub-page{
  display:none;
  padding:32px 36px;
  width:min(100%, 1480px);
  margin:0 auto;
}

.hub-page.active{display:block;}

.workspace-root{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  height:calc(100vh - 46px);
  padding:0;
  background:var(--bg);
}

.workspace-root.cols-2{grid-template-columns:1fr 1fr;}

.workspace-root.cols-3{grid-template-columns:1fr 1fr 1fr;}

.workspace-pane{
  min-width:0;
  min-height:0;
  border:none;
  border-right:1px solid rgba(255,255,255,0.08);
  border-radius:0;
  background:transparent;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  position:relative;
}

.ws-pane-close{
  position:absolute;
  top:6px;
  right:6px;
  z-index:20;
  width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:6px;
  color:var(--text3);
  font-size:14px;
  cursor:pointer;
  opacity:0;
  transition:opacity .15s,background .12s,color .12s;
  line-height:1;
}

.workspace-pane:hover .ws-pane-close{opacity:1;}

.ws-pane-close:hover{background:rgba(255,60,60,.18);color:#ff6b6b;border-color:rgba(255,60,60,.3);}

.workspace-pane:last-child{border-right:none;}

.workspace-pane.active{box-shadow:none;}

.workspace-pane-head{
  height:44px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:0 8px 0 10px;
  border-bottom:1px solid rgba(255,255,255,0.09);
  background:#202124;
  overflow-x:auto;
}

.workspace-tabs-track{
  display:flex;
  align-items:flex-end;
  gap:4px;
  min-width:0;
  overflow-x:auto;
  padding-top:6px;
  height:100%;
}

.workspace-tab{
  border:1px solid rgba(255,255,255,0.06);
  border-bottom-color:transparent;
  background:#2a2c31;
  color:#bcc0c7;
  border-radius:9px 9px 0 0;
  padding:7px 11px 8px;
  font-size:12px;
  white-space:nowrap;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:all .18s ease;
  transform:translateY(2px);
}

.workspace-tab:hover{
  background:#32353c;
  color:#e4e6eb;
}

.workspace-tab.active{
  color:#fff;
  background:#1e1f24;
  border-color:rgba(255,255,255,0.12);
  border-bottom-color:#1e1f24;
  transform:translateY(0);
  box-shadow:0 -2px 12px rgba(0,0,0,.28);
}

.workspace-tab span{
  opacity:.75;
  font-size:11px;
  line-height:1;
}

.workspace-tab span:hover{opacity:1;color:#fff;}

.workspace-tab-add{
  width:26px;
  height:26px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:7px;
  background:#2b2d33;
  color:#c9cdd3;
  font-size:17px;
  line-height:1;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:all .16s ease;
}

.workspace-tab-add:hover{
  background:#363942;
  color:#fff;
  border-color:rgba(255,255,255,.16);
}

.workspace-pane-body{
  flex:1;
  min-height:0;
  overflow:auto;
  background:#1e1e1e;
  animation:wsPaneFade .18s ease;
  position:relative;
}

.ws-drop-zones{
  position:absolute;
  inset:0;
  display:flex;
  align-items:stretch;
  gap:6px;
  padding:14px;
  z-index:200;
  background:rgba(10,10,14,.55);
  backdrop-filter:blur(3px);
  pointer-events:auto;
  animation:wsPaneFade .14s ease;
}

.ws-dz{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:2px dashed rgba(255,255,255,.14);
  border-radius:12px;
  cursor:copy;
  transition:border-color .12s,background .12s,box-shadow .12s;
  background:rgba(255,255,255,.03);
}

.ws-dz.active{
  border-color:var(--accent);
  border-style:solid;
  background:color-mix(in srgb,var(--accent) 18%,transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 50%,transparent);
}

.ws-dz-icon{
  font-size:26px;
  opacity:.45;
  pointer-events:none;
  line-height:1;
}

.ws-dz-lbl{
  font-size:10px;
  font-weight:600;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.1em;
  pointer-events:none;
}

.ws-dz.active .ws-dz-icon{opacity:1;}

.ws-dz.active .ws-dz-lbl{color:var(--accent2);}

.ws-dz-left{max-width:28%;}

.ws-dz-right{max-width:28%;}

/* ── new-tab page (empty pane) ── */

.ws-newtab-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:300px;gap:16px;padding:40px 20px;}

.ws-newtab-page .ws-ntp-big-icon{font-size:38px;opacity:.18;line-height:1;}

.ws-newtab-page .ws-ntp-heading{font-size:12px;font-weight:600;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;}

.ws-newtab-page .ws-ntp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;max-width:480px;width:100%;}

.ws-ntp-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;color:var(--text2);cursor:pointer;transition:background .12s,border-color .12s;}

.ws-ntp-card:hover{background:var(--accent-soft,rgba(124,106,255,.1));border-color:var(--accent);color:var(--accent2);}

.ws-ntp-card-icon{font-size:22px;}

.ws-ntp-card-label{font-size:10px;font-weight:500;text-align:center;line-height:1.3;}

/* ── new-tab popup (+ button) ── */

.ws-ntp-popup{position:fixed;z-index:2000;background:var(--bg2,#22242b);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 8px 32px rgba(0,0,0,.45);min-width:260px;}

.ws-ntp-popup-title{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border);}

.ws-ntp-popup-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;}

.ws-ntp-popup-btn{display:flex;align-items:center;gap:8px;padding:7px 10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:7px;color:var(--text2);font-size:12px;cursor:pointer;text-align:left;transition:background .1s,border-color .1s;}

.ws-ntp-popup-btn:hover{background:var(--accent-soft,rgba(124,106,255,.1));border-color:var(--accent);color:var(--accent2);}

.ws-ntp-popup-btn span:first-child{font-size:15px;}

.workspace-root:not(.cols-2):not(.cols-3) .workspace-pane-body{
  height:100%;
}

.workspace-pane .hub-page{
  height:auto;
  min-height:100%;
  overflow:visible;
  border:none;
  background:transparent;
}

.workspace-pane .hub-page:not(.notes-full):not(#hub-knowledge-map):not(#hub-trabalho){
  padding:32px 36px;
  width:min(100%, 1480px);
  margin:0 auto;
}

.workspace-pane .hub-page.notes-full{height:100%;display:flex;}

.workspace-pane .hub-page.notes-full .notes-split-host{height:100%;}

.workspace-pane #hub-knowledge-map,
.workspace-pane #hub-notes{
  padding:0;
  width:100%;
  margin:0;
}

.workspace-pane #hub-kb{
  width:100%;
  max-width:none;
  margin:0;
  padding:20px 10px 24px;
}

.workspace-pane #hub-kb .kbv-outer{
  max-width:1700px;
  margin:0 auto;
}

.workspace-pane #hub-kb .kbv-wrap{
  max-width:1320px;
}

.hub-page#hub-trabalho{width:100%;max-width:none;}

.hub-page#hub-kb{
  width:min(100%, 1660px);
}

/* workspace control com visual mais discreto/integrado */

.workspace-controls{gap:4px;padding-right:6px;}

.ws-ctl-btn{
  border:1px solid transparent;
  background:transparent;
  border-radius:7px;
  height:28px;
  color:var(--text3);
}

.ws-ctl-btn:hover{background:rgba(255,255,255,.05);color:var(--text2);}

.ws-ctl-btn:disabled{
  opacity:.4;
  cursor:not-allowed;
  background:transparent;
}

.ws-ctl-btn.active{
  border-color:rgba(140,124,255,.5);
  background:rgba(140,124,255,.10);
  color:#fff;
}

@keyframes wsPaneFade{
  from{opacity:.86;transform:translateY(2px);}
  to{opacity:1;transform:translateY(0);}
}

.hub-page#hub-knowledge-map{padding:0;}

/* caderno page fills height */

.hub-page.notes-full{display:none;padding:0;height:100vh;overflow:hidden;}

.hub-page.notes-full.active{display:flex;flex-direction:column;}

.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;}

.page-title{font-family:'Syne',sans-serif;font-size:26px;font-weight:700;color:var(--text);}

.page-sub{font-size:13px;color:var(--text3);margin-top:3px;}

/* ── BUTTONS ── */

.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;}

.btn-primary{background:var(--accent);color:#fff;}

.btn-primary:hover{background:var(--accent2);transform:translateY(-1px);}

.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border2);}

.btn-ghost:hover{color:var(--text);background:var(--surface3);}

.btn-danger{background:var(--red-soft);color:var(--red);}

.btn-danger:hover{background:rgba(255,94,94,.25);}

.btn-sm{padding:5px 10px;font-size:12px;}

/* AI quick action */

.ai-fab{
  position:fixed;
  right:20px;
  bottom:56px;
  width:40px;
  height:40px;
  border-radius:var(--radius-sm);
  border:1px solid rgba(124,106,255,0.4);
  background:var(--surface2);
  color:var(--accent2);
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:.02em;
  cursor:pointer;
  z-index:260;
  box-shadow:0 2px 8px rgba(0,0,0,.3);
  transition:background .15s, border-color .15s;
}

.ai-fab:hover{
  background:var(--surface3);
  border-color:var(--accent2);
}

.ai-fab:active{opacity:.8;}

@keyframes aiFabPulse{}

/* ── CARDS ── */

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;}

/* ── STATS ── */

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;}

.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;}

.stat-label{font-size:11px;color:var(--text3);font-weight:500;text-transform:uppercase;letter-spacing:.06em;}

.stat-val{font-family:'Syne',sans-serif;font-size:28px;font-weight:700;color:var(--text);margin-top:6px;}

.stat-sub{font-size:11px;color:var(--text3);margin-top:3px;}

.progress-bar{height:4px;background:var(--surface3);border-radius:99px;overflow:hidden;margin-top:8px;}

.progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .4s ease;}

/* ── TASKS ── */

.task-filters{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap;}

.filter-btn{padding:6px 14px;border-radius:99px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:none;color:var(--text2);transition:all .15s;}

.filter-btn.active,.filter-btn:hover{background:var(--accent-soft);color:var(--accent2);border-color:var(--accent);}

.task-list{display:flex;flex-direction:column;gap:8px;}

.task-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all .15s;position:relative;}

.task-item:hover{border-color:var(--border2);background:var(--surface2);}

.task-item.done{opacity:.45;}

.task-item.done .task-title{text-decoration:line-through;}

.task-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-top:1px;}

.task-check:hover{border-color:var(--accent);}

.task-check.checked{background:var(--accent);border-color:var(--accent);}

.task-check.checked::after{content:'✓';font-size:10px;color:#fff;font-weight:700;}

.task-content{flex:1;}

.task-title{font-size:14px;font-weight:500;color:var(--text);}

.task-meta{display:flex;gap:8px;margin-top:5px;flex-wrap:wrap;}

.task-tag{font-size:11px;padding:2px 8px;border-radius:99px;font-weight:500;}

.tag-work{background:var(--blue-soft);color:var(--blue);}

.tag-study{background:var(--accent-soft);color:var(--accent2);}

.tag-personal{background:var(--green-soft);color:var(--green);}

.tag-course{background:var(--amber-soft);color:var(--amber);}

.task-date{font-size:11px;color:var(--text3);}

.task-prio{font-size:10px;padding:2px 7px;border-radius:99px;font-weight:600;}

.prio-high{background:var(--red-soft);color:var(--red);}

.prio-med{background:var(--amber-soft);color:var(--amber);}

.prio-low{background:var(--green-soft);color:var(--green);}

.task-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s;}

.task-item:hover .task-actions{opacity:1;}

.task-del{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;}

.task-del:hover{color:var(--red);background:var(--red-soft);}

/* ── CALENDAR ── */

.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}

.cal-month{font-family:'Syne',sans-serif;font-size:20px;font-weight:600;}

.cal-nav{display:flex;gap:8px;}

.cal-nav button{background:var(--surface2);border:1px solid var(--border2);color:var(--text2);border-radius:var(--radius-sm);padding:6px 12px;cursor:pointer;font-size:14px;transition:all .15s;}

.cal-nav button:hover{background:var(--surface3);color:var(--text);}

.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}

.cal-day-name{text-align:center;font-size:11px;color:var(--text3);font-weight:500;text-transform:uppercase;padding:8px 0;letter-spacing:.06em;}

.cal-cell{min-height:80px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;cursor:pointer;transition:all .15s;}

.cal-cell:hover{border-color:var(--border2);background:var(--surface2);}

.cal-cell.today{border-color:var(--accent);background:var(--accent-soft);}

.cal-cell.other-month .cal-num{color:var(--text3);}

.cal-num{font-size:13px;font-weight:500;color:var(--text);}

.cal-cell.today .cal-num{color:var(--accent2);font-weight:700;}

.cal-event{font-size:10px;padding:1px 5px;border-radius:3px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;}

.ev-work{background:var(--blue-soft);color:var(--blue);}

.ev-study{background:var(--accent-soft);color:var(--accent2);}

.ev-personal{background:var(--green-soft);color:var(--green);}

.ev-course{background:var(--amber-soft);color:var(--amber);}

.cal-layout{display:grid;grid-template-columns:1fr 280px;gap:20px;}

.upcoming-list{display:flex;flex-direction:column;gap:8px;}

.upcoming-item{padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);}

.upcoming-date{font-size:10px;color:var(--text3);margin-bottom:3px;}

.upcoming-title{font-size:13px;font-weight:500;}

/* ── ALARMS ── */

.alarm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;}

.alarm-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;transition:all .15s;}

.alarm-card:hover{border-color:var(--border2);}

.alarm-card.active-alarm{border-color:var(--accent);background:var(--accent-soft);}

.alarm-time{font-family:'Syne',sans-serif;font-size:32px;font-weight:700;color:var(--text);}

.alarm-label{font-size:14px;color:var(--text2);margin-top:4px;}

.alarm-days{display:flex;gap:4px;margin-top:10px;flex-wrap:wrap;}

.alarm-day{font-size:10px;padding:2px 6px;border-radius:4px;background:var(--surface2);color:var(--text3);font-weight:500;}

.alarm-day.on{background:var(--accent-soft);color:var(--accent2);}

.alarm-toggle{position:absolute;top:18px;right:18px;}

.toggle{width:36px;height:20px;background:var(--surface3);border-radius:99px;cursor:pointer;position:relative;transition:background .2s;border:none;}

.toggle.on{background:var(--accent);}

.toggle::after{content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .2s;}

.toggle.on::after{left:19px;}

.alarm-next{font-size:11px;color:var(--text3);margin-top:8px;}

/* ── MODAL ── */

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);}

.modal-overlay.open{display:flex;}

.modal{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:28px;width:460px;max-width:95vw;animation:slideUp .2s ease;}

@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.modal-title{font-family:'Syne',sans-serif;font-size:18px;font-weight:600;margin-bottom:20px;}

.form-group{margin-bottom:14px;}

.form-label{font-size:12px;color:var(--text2);margin-bottom:6px;display:block;font-weight:500;}

.form-input,.form-select,.form-textarea{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:9px 12px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);outline:none;transition:border .15s;}

.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);}

.form-select option{background:var(--surface2);}

.form-textarea{resize:vertical;min-height:80px;}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;}

/* ── KB icon picker in modals ── */

.kb-modal-icon-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;}

.kb-modal-icon-preview{width:42px;height:42px;border-radius:10px;background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent2);}

.kb-modal-icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(34px,1fr));gap:4px;max-height:180px;overflow-y:auto;padding:4px 0;margin-top:6px;}

.kb-icon-pick-btn{width:34px;height:34px;padding:0;border:1px solid transparent;border-radius:7px;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:all .12s;}

.kb-icon-pick-btn:hover{background:var(--surface2);color:var(--accent2);border-color:var(--border2);}

.kb-icon-pick-btn.selected{background:var(--accent-soft);color:var(--accent2);border-color:var(--accent);}

.kb-tag-select{display:flex;gap:5px;flex-wrap:wrap;}

.kb-modal-error{color:#ff6b6b;font-size:12px;margin-bottom:8px;display:none;}

/* KB confirm modal */

.kb-confirm-modal{text-align:center;max-width:360px;}

.kb-confirm-icon{display:flex;justify-content:center;margin-bottom:14px;}

.kb-confirm-msg{font-size:16px;font-weight:600;margin-bottom:6px;}

.kb-confirm-sub{font-size:13px;color:var(--text3);margin-bottom:4px;}

/* ── NOTIF ── */

.notif{position:fixed;top:20px;right:20px;z-index:200;background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);padding:14px 18px;min-width:280px;max-width:340px;animation:slideIn .3s ease;box-shadow:0 0 30px var(--accent-glow);}

@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

.notif-title{font-size:13px;font-weight:600;color:var(--accent2);margin-bottom:3px;}

.notif-body{font-size:13px;color:var(--text2);}

/* ── RING ── */

.ring-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;display:none;flex-direction:column;align-items:center;justify-content:center;backdrop-filter:blur(8px);}

.ring-overlay.open{display:flex;}

.ring-time{font-family:'Syne',sans-serif;font-size:64px;font-weight:700;color:var(--accent2);animation:pulse 1s ease infinite;}

.ring-label{font-size:20px;color:var(--text2);margin-top:8px;margin-bottom:32px;}

@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* ── EMPTY ── */

.empty{text-align:center;padding:60px 20px;color:var(--text3);}

.empty-icon{font-size:36px;margin-bottom:10px;}

.empty-text{font-size:14px;}

/* ══════════════════════════════════════
   CADERNO — editor de blocos
══════════════════════════════════════ */

.note-editor-toolbar{
  padding:8px 48px;display:flex;align-items:center;gap:4px;flex-wrap:wrap;
  background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;
}

.tb-btn{padding:5px 9px;border-radius:var(--radius-sm);background:none;border:none;font-size:12px;color:var(--text2);cursor:pointer;transition:all .12s;font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:4px;}

.tb-btn:hover{background:var(--surface2);color:var(--text);}

.tb-sep{width:1px;height:16px;background:var(--border2);margin:0 3px;}

.note-editor-area{flex:1;overflow-y:auto;background:var(--bg);}

.global-tabs-bar{
  height:46px;display:flex;align-items:flex-end;gap:3px;padding:0 8px 0 8px;
  background:transparent;border-bottom:none;flex-shrink:0;overflow-x:auto;
}

.nb-topbar .global-tabs-bar{
  flex:1;
  height:100%;
  padding:0 4px;
  background:transparent;
  border-bottom:none;
}

.global-tab{
  border:1px solid rgba(255,255,255,0.05);
  border-bottom-color:transparent;
  background:linear-gradient(180deg,#32353c 0%,#2a2d33 100%);
  color:#8d94a0;
  border-radius:9px 9px 0 0;
  padding:8px 14px 11px 11px;
  font-size:13.5px;
  line-height:1;
  cursor:grab;
  white-space:nowrap;
  display:flex;align-items:center;gap:8px;
  min-width:150px;
  max-width:230px;
  transition:background .15s ease,transform .15s ease,color .15s ease,box-shadow .15s ease;
  transform:translateY(4px);
  box-shadow:1px -1px 6px rgba(0,0,0,.22);
  position:relative;
}

.global-tab:hover{
  background:linear-gradient(180deg,#3c404a 0%,#33363e 100%);
  color:#c7ccd3;
  transform:translateY(2px);
  border-color:rgba(255,255,255,0.09);
  box-shadow:1px -2px 10px rgba(0,0,0,.28);
}

.global-tab:active{cursor:grabbing;}

.global-tab.active{
  background:#1f2024;
  color:#fff;
  border-color:rgba(255,255,255,0.08);
  border-top-color:var(--accent);
  border-bottom-color:#1f2024;
  box-shadow:0 -3px 14px rgba(0,0,0,.32);
  transform:translateY(0);
  cursor:default;
}

.global-tab-close{opacity:.65;cursor:pointer;transition:all .16s ease;}

.global-tab-close{margin-left:auto;}

.global-tab-close:hover{opacity:1;color:#fff;}

.global-tab-dot{
  font-size:10px;
  opacity:.45;
  letter-spacing:-1px;
  flex-shrink:0;
}

.global-tab:hover .global-tab-dot{opacity:.7;}

.global-tab.active .global-tab-dot{opacity:.8;}

.global-tab-new{
  background:#1e1e1e;
  color:#aeb4be;
  border-radius:8px 8px 0 0;
  padding:12px 14px 13px;
  transform:translateY(0);
  border:1px solid transparent;
  min-width:140px;
  font-size:14px;
}

.global-tab-new:hover{
  background:#1e1e1e;
  color:#e9edf5;
}

.global-tab-plus{
  margin-left:4px;
  width:28px;
  height:28px;
  align-self:center;
  border:none;
  background:transparent;
  color:#6b7280;
  font-size:20px;
  line-height:1;
  cursor:pointer;
  border-radius:6px;
  transition:all .15s ease;
  display:flex;align-items:center;justify-content:center;
}

.global-tab-plus:hover{color:#c7ccd3;background:rgba(255,255,255,.07);}

.notes-split-host{flex:1;display:flex;min-height:0;min-width:0;}

.notes-split-host.split-down{flex-direction:column;}

.notes-pane{display:flex;flex-direction:column;min-width:0;min-height:0;flex:1;}

.notes-tabbar{
  height:38px;display:flex;align-items:center;gap:6px;padding:0 8px;
  background:linear-gradient(180deg,#191b20 0%, #17181d 100%);
  border-bottom:1px solid rgba(255,255,255,0.08);
  overflow-x:auto;overflow-y:hidden;
}

.notes-tab{
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.03);
  color:#c8cbcf;
  border-radius:10px;
  padding:6px 10px;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  white-space:nowrap;
  display:flex;align-items:center;gap:8px;
  transition:all .14s ease;
}

.notes-tab:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.15);}

.notes-tab.active{
  background:#1f2127;
  color:#fff;
  border-color:#8c7cff;
  box-shadow:0 0 0 1px rgba(140,124,255,0.18) inset;
}

.notes-tab-close{opacity:.7;cursor:pointer;}

.notes-tab-close:hover{opacity:1;color:#fff;}

.notes-tab-add{
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.03);
  color:var(--text3);
  cursor:pointer;
  padding:4px 8px;
  border-radius:8px;
  font-size:14px;
}

.notes-tab-add:hover{background:rgba(255,255,255,0.06);color:var(--text);}

.notes-secondary-pane{
  border-left:1px solid var(--border);
  background:var(--bg);
  min-width:280px;
  width:38%;
  display:flex;
  flex-direction:column;
  min-height:0;
}

.notes-split-host.split-down .notes-secondary-pane{
  border-left:none;
  border-top:1px solid var(--border);
  width:100%;
  min-width:0;
  min-height:200px;
}

.notes-secondary-body{flex:1;overflow:auto;padding:10px;}

.kb-split-host{display:flex;min-height:0;min-width:0;flex:1;position:relative;}

.kb-split-host.split-down{flex-direction:column;}

.kb-split-host.split-reverse{flex-direction:row-reverse;}

.kb-split-host.split-down.split-reverse{flex-direction:column-reverse;}

.kb-split-secondary{
  display:flex;flex-direction:column;min-width:280px;width:38%;
  border-left:1px solid var(--border);background:var(--bg);min-height:0;
}

.kb-split-host.split-reverse .kb-split-secondary{border-left:none;border-right:1px solid var(--border);}

.kb-split-host.split-down .kb-split-secondary{
  width:100%;min-width:0;min-height:200px;border-left:none;border-top:1px solid var(--border);
}

.kb-split-host.split-down.split-reverse .kb-split-secondary{border-top:none;border-bottom:1px solid var(--border);}

.kb-split-dropzones{
  position:absolute;inset:0;pointer-events:none;z-index:6;
}

.kb-drop-zone{
  position:absolute;border:1px dashed transparent;background:transparent;border-radius:10px;
  transition:all .12s ease;
}

.kb-drop-zone.left{left:8px;top:8px;bottom:8px;width:24%;}

.kb-drop-zone.right{right:8px;top:8px;bottom:8px;width:24%;}

.kb-drop-zone.top{left:8px;right:8px;top:8px;height:24%;}

.kb-drop-zone.bottom{left:8px;right:8px;bottom:8px;height:24%;}

.kb-drop-zone.center{left:32%;right:32%;top:32%;bottom:32%;}

.kb-drop-zone.active{
  border-color:var(--accent);
  background:color-mix(in srgb, var(--accent) 28%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 70%, transparent);
}

.nsp-wrap{display:flex;flex-direction:column;gap:8px;}

.nsp-note-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:4px;}

.nsp-line{font-size:13px;color:var(--text2);line-height:1.6;border-bottom:1px solid var(--border);padding-bottom:6px;}

.nsp-item{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  text-align:left;
  background:var(--surface2);
  border:1px solid var(--border);
  color:var(--text);
  padding:8px 10px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  font-size:12px;
}

.nsp-item:hover{border-color:var(--accent);background:var(--accent-soft);}

.nsp-item span{font-size:10px;color:var(--text3);}

.nsp-flow-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:6px;
}

.nsp-flow-item span:first-child{
  font-size:12px;
  color:var(--text);
  font-weight:600;
}

.kbp-wrap{gap:10px;}

.kbp-content{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding-right:2px;
}

.kbp-p{font-size:14px;line-height:1.7;color:var(--text2);}

.kbp-h1,.kbp-h2,.kbp-h3{
  margin:0;
  color:var(--text);
  line-height:1.35;
}

.kbp-h1{font-size:24px;font-weight:700;}

.kbp-h2{font-size:20px;font-weight:700;}

.kbp-h3{font-size:16px;font-weight:600;}

.kbp-li{
  display:flex;
  align-items:flex-start;
  gap:8px;
  font-size:14px;
  line-height:1.65;
  color:var(--text2);
}

.kbp-dot{margin-top:1px;color:var(--text3);}

.kbp-quote{
  margin:0;
  padding:8px 10px;
  border-left:3px solid var(--accent2);
  background:var(--surface2);
  color:var(--text2);
  border-radius:8px;
  font-size:13px;
  line-height:1.6;
}

.kbp-code{
  margin:0;
  padding:10px 12px;
  border:1px solid var(--border2);
  border-radius:10px;
  background:#0b1222;
  color:#e9efff;
  overflow:auto;
}

.kbp-code code{
  font-family:'DM Mono',monospace;
  font-size:12px;
  line-height:1.6;
}

.kbp-callout{
  display:flex;
  gap:8px;
  padding:8px 10px;
  border:1px solid var(--border2);
  border-radius:10px;
  background:var(--surface2);
  color:var(--text2);
  font-size:13px;
  line-height:1.6;
}

.kbp-divider{
  border:none;
  border-top:1px solid var(--border);
  margin:2px 0;
}

.kbp-image{
  margin:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.kbp-image img{
  width:100%;
  border-radius:10px;
  border:1px solid var(--border2);
}

.kbp-image figcaption{
  font-size:12px;
  color:var(--text3);
}

.kbp-colrow{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.kbp-col{
  border:1px solid var(--border2);
  border-radius:10px;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:8px;
  min-height:40px;
}

.kbp-empty{
  font-size:12px;
  color:var(--text3);
}

.ne-cover{width:100%;height:160px;position:relative;overflow:hidden;cursor:pointer;background:var(--gradient-cover);}

.ne-cover img{width:100%;height:100%;object-fit:cover;}

.ne-cover-btn{position:absolute;bottom:10px;left:48px;background:rgba(255,255,255,.15);color:#fff;border:none;border-radius:var(--radius-sm);padding:4px 10px;font-size:12px;cursor:pointer;backdrop-filter:blur(4px);font-family:'DM Sans',sans-serif;}

.ne-title-wrap{padding:28px 48px 8px;}

.ne-emoji{font-size:48px;margin-bottom:6px;cursor:pointer;display:inline-block;user-select:none;}

.ne-title{font-family:'Lora',serif;font-size:34px;font-weight:600;color:var(--text);border:none;outline:none;background:none;width:100%;line-height:1.2;caret-color:var(--accent);}

.ne-title::placeholder{color:var(--text3);}

.ne-meta{font-size:11px;color:var(--text3);margin-top:6px;padding-bottom:14px;border-bottom:1px solid var(--border);}

.blocks-wrap{padding:10px 48px 80px;}

/* blocks */

.b-row{display:flex;align-items:flex-start;gap:8px;min-height:28px;margin-bottom:2px;position:relative;border-radius:4px;transition:background .1s;}

.b-row:hover{background:rgba(124,106,255,.04);}

.b-row:hover .b-handle{opacity:1;}

.b-row.kb-dragging{opacity:.35;}

.b-row.kb-drag-over-right{outline:none;background:rgba(124,106,255,.08);}

.b-row.kb-drag-over-right::after{
  content:'↔ Criar coluna';
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-size:11px;font-weight:600;color:var(--accent2);
  background:rgba(124,106,255,.15);padding:2px 8px;border-radius:99px;
  border:1px solid var(--accent2);pointer-events:none;
}

.b-row.kb-drag-over-right .b-content{border-right:3px solid var(--accent);}

.b-handle{opacity:0;display:flex;align-items:center;gap:1px;padding-top:3px;flex-shrink:0;width:52px;justify-content:flex-end;transition:opacity .15s;}

.b-drag{cursor:grab;color:var(--text3);font-size:14px;line-height:1;padding:2px 2px;border-radius:3px;user-select:none;}

.b-drag:hover{background:var(--surface2);color:var(--text);}

.b-drag:active{cursor:grabbing;}

.b-handle,.b-handle *,.kb-ui-no-copy{user-select:none;-webkit-user-select:none;}

.b-type-btn{font-size:10px;font-weight:700;min-width:20px;text-align:center;font-family:'DM Mono',monospace;}

.b-hbtn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:13px;padding:2px 3px;border-radius:3px;}

.b-hbtn:hover{background:var(--surface2);color:var(--text);}

.b-content{flex:1;min-width:0;}

.b-del{
  opacity:0;position:absolute;right:4px;top:50%;transform:translateY(-50%);
  background:var(--surface);border:1px solid var(--border2);color:var(--text3);cursor:pointer;
  width:24px;height:24px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;padding:0;
}

.b-row:hover .b-del,.b-row:focus-within .b-del{opacity:.9;}

.b-del:hover{opacity:1;color:var(--red);background:rgba(255,94,94,.1);border-color:rgba(255,94,94,.42);}

.b-del:focus-visible{outline:2px solid var(--accent2);outline-offset:1px;opacity:1;}

.b-del svg{width:12px;height:12px;stroke:currentColor;pointer-events:none;}

/* drop indicator line */

.kb-drop-line{height:2px;background:var(--accent);border-radius:2px;margin:1px 0;pointer-events:none;}

/* column layout */

.kb-col-row{display:flex;align-items:stretch;gap:0;position:relative;margin-bottom:2px;border-radius:4px;}

.kb-col-row:hover .kb-col-row-del{opacity:1;}

.kb-col-row-del{
  opacity:0;position:absolute;left:-22px;top:4px;
  background:none;border:none;cursor:pointer;color:var(--text3);
  font-size:14px;padding:2px;border-radius:3px;transition:all .12s;
}

.kb-col-row-del:hover{color:var(--accent);background:var(--surface2);}

.kb-col{flex:1;min-width:0;padding:0 8px;border-radius:4px;transition:background .1s;position:relative;}

.kb-col:first-child{padding-left:0;}

.kb-col:last-child{padding-right:0;}

.kb-col-add{
  height:24px;cursor:text;display:flex;align-items:center;
  opacity:0;transition:opacity .15s;
}

.kb-col:hover .kb-col-add{opacity:1;}

.kb-col-add span{font-size:11px;color:var(--text3);}

.kb-col-del{
  position:absolute;top:2px;right:10px;
  background:none;border:none;cursor:pointer;
  color:var(--text3);font-size:12px;padding:2px 4px;
  border-radius:3px;opacity:0;transition:all .12s;z-index:2;
}

.kb-col:hover .kb-col-del{opacity:1;}

.kb-col-del:hover{color:#ff5e5e;background:rgba(255,94,94,.1);}

.kb-col-resize{
  width:8px;flex-shrink:0;cursor:col-resize;
  display:flex;align-items:stretch;justify-content:center;position:relative;
}

.kb-col-resize::after{
  content:'';position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:2px;border-radius:1px;
  background:var(--border2);transition:background .15s;
}

.kb-col-resize:hover::after{background:var(--accent);}

/* slash menu */

.kb-slash-menu{
  position:absolute;z-index:600;
  background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.3);
  min-width:220px;max-height:280px;overflow-y:auto;padding:4px;
  display:none;
}

.kb-slash-item{
  display:flex;align-items:center;gap:10px;
  padding:7px 10px;border-radius:6px;cursor:pointer;
  transition:background .1s;
}

.kb-slash-item:hover,.kb-slash-item.active{background:var(--surface2);}

.kb-slash-icon{font-size:13px;font-weight:700;width:26px;text-align:center;flex-shrink:0;font-family:'DM Mono',monospace;color:var(--text2);}

.kb-slash-label{font-size:13px;font-weight:500;color:var(--text);flex:1;}

.kb-slash-hint{font-size:11px;color:var(--text3);}

/* type switcher menu */

.kb-type-menu{
  position:fixed;z-index:601;
  background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.3);
  min-width:180px;max-height:280px;overflow-y:auto;padding:4px;
}

.kb-type-item{
  display:flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:6px;cursor:pointer;
  transition:background .1s;
}

.kb-type-item:hover{background:var(--surface2);}

/* Barra de ação dos blocos ricos (arquivo, imagem, tabela, etc.) */

.b-block-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:4px 8px;margin-bottom:4px;
  background:var(--surface2);border-radius:var(--radius-sm);
  border:1px solid var(--border);
}

.b-block-label{font-size:11px;color:var(--text3);font-family:'DM Mono',monospace;}

.b-block-del{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:7px;
  background:var(--surface);border:1px solid var(--border2);
  color:var(--text3);cursor:pointer;transition:all .12s;padding:0;
}

.b-block-del:hover{background:rgba(255,94,94,.12);color:#ff5e5e;border-color:rgba(255,94,94,.5);}

.b-block-del:focus-visible{outline:2px solid var(--accent2);outline-offset:1px;}

.b-block-del svg{width:12px;height:12px;stroke:currentColor;pointer-events:none;}

.b-block-del-inline{
  width:24px;height:24px;padding:0 !important;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--text3) !important;
}

.b-block-del-inline:hover{color:#ff5e5e !important;border-color:rgba(255,94,94,.5);}

.kb-add-area{
  min-height:48px;cursor:text;display:flex;align-items:center;
  padding:4px 0 24px;margin-top:2px;
}

.kb-add-area-hint{
  font-size:12px;color:transparent;user-select:none;
  transition:color .15s;padding:2px 4px;border-radius:4px;
}

.kb-add-area:hover .kb-add-area-hint{color:var(--text3);}

/* mode bar — full-width row above toolbar */

.kbv-mode-bar{
  display:flex;justify-content:center;align-items:center;
  padding:14px 0 10px;border-bottom:1px solid var(--border);
  margin-bottom:0;
}

/* mode toggle — segmented control */

.kb-mode-toggle{
  display:flex;
  background:var(--surface2);
  border:1px solid var(--border2);
  border-radius:10px;
  padding:3px;gap:3px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}

.kb-mode-btn{
  display:flex;align-items:center;gap:7px;
  background:none;border:none;border-radius:8px;
  padding:8px 22px;font-size:13px;font-weight:600;
  color:var(--text3);cursor:pointer;transition:all .18s;
  font-family:inherit;white-space:nowrap;
}

.kb-mode-btn.active{
  background:var(--surface);color:var(--text);
  box-shadow:0 1px 6px rgba(0,0,0,.18);
}

.kb-mode-btn.active svg{stroke:var(--accent2);}

.kb-mode-btn:not(.active):hover{color:var(--text2);background:var(--surface3);}

/* hide toolbar's old separator that was after the toggle */

.kbv-caderno-toolbar > .kb-mode-toggle { display: none; }

/* canvas mode wrapper fills the area */

.bcanvas-mode{display:flex;flex-direction:column;}

/* ══════════════════════════════════════
   FREE CANVAS BLOCK
   ══════════════════════════════════════ */

.bcanvas,.bcanvas-mode .bc-area{border-radius:0;}

.bc-toolbar{
  display:flex;align-items:center;gap:4px;flex-wrap:wrap;
  padding:6px 10px;background:var(--surface2);border-bottom:1px solid var(--border);
}

.bc-tb-label{font-size:9px;font-weight:700;color:var(--text3);letter-spacing:.08em;margin-right:4px;white-space:nowrap;}

.bc-btn{
  background:none;border:1px solid var(--border2);border-radius:var(--radius-sm);
  color:var(--text2);cursor:pointer;font-size:11px;padding:3px 9px;
  transition:all .12s;font-family:inherit;white-space:nowrap;
}

.bc-btn:hover{background:var(--surface3);color:var(--text);}

.bc-btn-active{background:rgba(124,106,255,.15) !important;color:var(--accent2) !important;border-color:var(--accent2) !important;}

.bc-btn-del{color:var(--text3);}

.bc-btn-del:hover{color:#ff5e5e;border-color:#ff5e5e;background:rgba(255,94,94,.08);}

.bc-sep{width:1px;height:14px;background:var(--border2);margin:0 2px;flex-shrink:0;}

/* Canvas area — graph-paper background */

.bc-area{
  position:relative;overflow:hidden;
  background-color:var(--surface);
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size:24px 24px;
  cursor:default;
  user-select:none;
}

.bc-area.bc-arrow-mode{cursor:crosshair;}

.bc-area.bc-arrow-mode .bc-item{cursor:crosshair;}

.bc-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none;}

.bc-hint{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:12px;color:var(--text3);text-align:center;padding:16px;
  pointer-events:none;line-height:1.7;
}

/* ── Items (float freely) ── */

.bc-item{position:absolute;min-width:80px;min-height:36px;}

.bc-item-top{
  display:flex;align-items:center;gap:4px;
  padding:3px 4px;opacity:0;transition:opacity .15s;
  border-radius:var(--radius-sm) var(--radius-sm) 0 0;
}

.bc-item:hover .bc-item-top,
.bc-item:focus-within .bc-item-top{opacity:1;}

.bc-drag-dots{
  cursor:grab;font-size:13px;color:rgba(0,0,0,.35);
  padding:0 2px;line-height:1;flex-shrink:0;
}

.bc-drag-dots:active{cursor:grabbing;}

.bc-del{
  margin-left:auto;background:rgba(0,0,0,.18);border:none;border-radius:50%;
  width:15px;height:15px;font-size:10px;line-height:1;cursor:pointer;
  color:#fff;display:flex;align-items:center;justify-content:center;padding:0;
  flex-shrink:0;
}

.bc-del:hover{background:#ff5e5e;}

.bc-ce{outline:none;word-break:break-word;line-height:1.6;}

.bc-ce:empty::before{color:rgba(0,0,0,.3);pointer-events:none;}

.bc-rz{
  position:absolute;bottom:2px;right:3px;
  font-size:10px;color:rgba(0,0,0,.3);cursor:se-resize;
  opacity:0;transition:opacity .15s;line-height:1;
  user-select:none;
}

.bc-item:hover .bc-rz,
.bc-item:focus-within .bc-rz{opacity:1;}

/* ── Sticky note ── */

.bc-sticky{border-radius:6px;box-shadow:2px 4px 12px rgba(0,0,0,.22);}

.bc-sticky .bc-drag-dots{color:rgba(0,0,0,.4);}

.bc-sticky .bc-item-top{padding:4px 6px;}

.bc-sticky .bc-ce{
  padding:6px 10px 14px;font-size:13px;color:#1a1917;
  min-height:56px;
}

.bc-color-row{display:flex;gap:3px;align-items:center;}

.bc-dot{
  width:11px;height:11px;border-radius:50%;cursor:pointer;
  border:1.5px solid rgba(0,0,0,.15);transition:transform .1s;flex-shrink:0;
}

.bc-dot:hover{transform:scale(1.35);}

/* ── Free text ── */

.bc-ftext{background:transparent;}

.bc-ftext .bc-item-top{background:rgba(124,106,255,.08);border-radius:4px 4px 0 0;}

.bc-ftext .bc-drag-dots{color:var(--text3);}

.bc-ftext .bc-del{background:var(--surface2);color:var(--text3);}

.bc-ftext .bc-del:hover{background:#ff5e5e;color:#fff;}

.bc-text-ce{
  padding:4px 6px;font-size:14px;color:var(--text);
  min-height:28px;border-radius:0 0 4px 4px;
}

.bc-text-ce:focus{background:rgba(124,106,255,.05);border-radius:0 0 4px 4px;}

/* ── Palette toolbar ── */

.bc-toolbar{flex-wrap:wrap;gap:3px;padding:5px 8px;}

.bc-pg-label{
  font-size:9px;font-weight:700;color:var(--text3);letter-spacing:.08em;
  align-self:center;white-space:nowrap;padding:0 2px;
}

.bc-pb{
  display:flex;flex-direction:column;align-items:center;gap:1px;
  background:none;border:1px solid transparent;border-radius:6px;
  color:var(--text2);cursor:pointer;font-family:inherit;
  padding:4px 6px;min-width:44px;transition:all .12s;
}

.bc-pb:hover{background:var(--surface3);border-color:var(--border2);color:var(--text);}

.bc-pb.bc-btn-active{background:rgba(124,106,255,.12);border-color:var(--accent2);color:var(--accent2);}

.bc-pb-icon{font-size:13px;font-weight:700;line-height:1;font-family:inherit;}

.bc-pb-label{font-size:9px;line-height:1;white-space:nowrap;}

.bc-btn-sm{font-size:11px;padding:3px 8px;}

.bc-arrow-hint{font-size:11px;color:var(--accent2);margin-left:6px;align-self:center;}

/* ── Type badge ── */

.bc-type-badge{
  font-size:9px;font-weight:700;letter-spacing:.06em;color:var(--text3);
  background:var(--surface3);border-radius:3px;padding:1px 5px;
  white-space:nowrap;flex-shrink:0;
}

/* ── Selection ring ── */

.bc-selected{outline:2px solid var(--accent2) !important;outline-offset:2px;}

/* ── Headings ── */

.bci-heading{background:var(--surface);border-radius:6px;box-shadow:0 1px 6px rgba(0,0,0,.12);}

.bci-heading .bc-item-top{border-radius:6px 6px 0 0;background:var(--surface2);}

.bci-heading-ce{padding:6px 12px 10px;font-weight:700;color:var(--text);line-height:1.2;}

.bci-h1 .bci-heading-ce{font-size:28px;}

.bci-h2 .bci-heading-ce{font-size:22px;}

.bci-h3 .bci-heading-ce{font-size:17px;}

.bci-h1 .bc-type-badge{color:var(--accent);}

.bci-h2 .bc-type-badge{color:#ff8c42;}

.bci-h3 .bc-type-badge{color:#5cb85c;}

/* ── List / Todo ── */

.bci-list{background:var(--surface);border-radius:6px;box-shadow:0 1px 6px rgba(0,0,0,.12);}

.bci-list .bc-item-top{background:var(--surface2);border-radius:6px 6px 0 0;}

.bc-list-body{padding:6px 10px 10px;display:flex;flex-direction:column;gap:4px;}

.bc-list-row{display:flex;align-items:flex-start;gap:6px;}

.bc-bullet-dot{color:var(--accent2);font-size:16px;line-height:1.5;flex-shrink:0;}

.bc-list-ce{flex:1;font-size:13px;color:var(--text);line-height:1.5;min-height:20px;}

.bc-todo-done{text-decoration:line-through;color:var(--text3);}

.bc-todo-cb{margin-top:3px;accent-color:var(--accent2);cursor:pointer;flex-shrink:0;}

.bc-list-add{
  background:none;border:1px solid var(--border2);border-radius:4px;
  color:var(--text3);cursor:pointer;font-size:10px;padding:1px 6px;
  font-family:inherit;flex-shrink:0;
}

.bc-list-add:hover{color:var(--text);border-color:var(--accent2);}

/* ── Code block ── */

.bci-code{background:#1a1b26;border-radius:6px;box-shadow:0 2px 12px rgba(0,0,0,.35);}

.bci-code-top{background:#12131e;border-radius:6px 6px 0 0;}

.bci-code-badge{background:rgba(124,106,255,.18);color:var(--accent2);}

.bci-code-del{background:transparent !important;color:rgba(255,255,255,.4) !important;}

.bci-code-del:hover{background:#ff5e5e !important;color:#fff !important;}

.bci-code-ce{
  padding:10px 14px 14px;font-size:12px;font-family:'Fira Code',Consolas,monospace;
  color:#a9b1d6;line-height:1.7;white-space:pre-wrap;min-height:48px;
  border-radius:0 0 6px 6px;
}

.bci-code-ce:focus{background:rgba(124,106,255,.04);}

/* ── Quote ── */

.bci-quote{
  background:var(--surface);border-radius:6px;
  border-left:4px solid var(--accent2);
  box-shadow:0 1px 6px rgba(0,0,0,.10);
}

.bci-quote .bc-item-top{border-radius:0;}

.bci-quote-ce{
  padding:8px 14px 12px;font-size:14px;font-style:italic;
  color:var(--text2);line-height:1.6;min-height:36px;
}

/* ── Callout ── */

.bci-callout{
  background:var(--callout-bg,#fff9db);border-radius:6px;
  box-shadow:0 1px 6px rgba(0,0,0,.10);
}

.bci-callout .bc-item-top{background:rgba(0,0,0,.04);border-radius:6px 6px 0 0;}

.bc-callout-icon{
  font-size:16px;cursor:text;border-radius:4px;padding:0 2px;
  transition:background .1s;
}

.bc-callout-icon:hover{background:rgba(0,0,0,.08);}

.bci-callout-ce{
  padding:6px 12px 12px;font-size:13px;color:#2c2a22;line-height:1.6;min-height:40px;
}

/* ── Sticky (updated) ── */

.bc-sticky-ce{padding:8px 10px 14px;font-size:13px;color:#1a1917;min-height:60px;}

/* ── Image ── */

.bci-image{background:var(--surface);border-radius:6px;box-shadow:0 1px 6px rgba(0,0,0,.12);overflow:hidden;}

.bci-image .bc-item-top{background:var(--surface2);}

.bci-img{display:block;width:100%;height:auto;border-radius:0 0 6px 6px;}

.bci-image-empty{min-height:80px;}

.bci-img-placeholder{
  display:flex;align-items:center;justify-content:center;
  min-height:80px;cursor:pointer;color:var(--text3);font-size:13px;
  border-radius:0 0 6px 6px;border:2px dashed var(--border2);margin:6px;
  transition:all .12s;
}

.bci-img-placeholder:hover{border-color:var(--accent2);color:var(--accent2);background:rgba(124,106,255,.04);}

/* ── Arrow start dot ── */

.bc-arrow-dot{
  position:absolute;width:12px;height:12px;border-radius:50%;
  background:var(--accent);transform:translate(-50%,-50%);
  pointer-events:none;box-shadow:0 0 0 3px rgba(124,106,255,.3);
  animation:bc-pulse .8s infinite alternate;
}

@keyframes bc-pulse{to{box-shadow:0 0 0 6px rgba(124,106,255,.1);}}

[contenteditable]{outline:none;caret-color:var(--accent);}

[contenteditable]:empty:focus::before{content:attr(data-ph);color:var(--text3);pointer-events:none;}

.bp{font-size:15px;line-height:1.75;color:var(--text);min-height:26px;word-break:break-word;}

.bh1{font-family:'Lora',serif;font-size:28px;font-weight:600;line-height:1.3;color:var(--text);min-height:38px;margin-top:6px;}

.bh2{font-family:'Lora',serif;font-size:22px;font-weight:600;line-height:1.4;color:var(--text);min-height:30px;margin-top:4px;}

.bh3{font-size:17px;font-weight:600;line-height:1.5;color:var(--text2);min-height:26px;}

.bquote{border-left:3px solid var(--accent);padding-left:14px;font-family:'Lora',serif;font-style:italic;font-size:15px;color:var(--text2);min-height:26px;}

.bcode{font-family:'DM Mono',monospace;font-size:13px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;min-height:36px;white-space:pre-wrap;color:var(--blue);}

.bcode-wrap{background:#17181c;border:1px solid #2a2d34;border-radius:12px;overflow:hidden;}

.bcode-topbar{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:#1f2127;border-bottom:1px solid #2a2d34;}

.bcode-lang{background:#13151a;color:#e6e7ea;border:1px solid #343843;border-radius:8px;padding:4px 8px;font-size:11px;font-family:'DM Sans',sans-serif;outline:none;}

.bcode-detected{font-size:10px;color:#9ba2b0;letter-spacing:.04em;text-transform:uppercase;}

.bcode-live{margin:0;padding:12px 14px;background:#111317;overflow:visible;max-height:none;}

.bcode-edit{display:block;white-space:pre;min-height:0;height:auto;font-family:'DM Mono',monospace;font-size:13px;line-height:1.55;color:#d6dae3;outline:none;tab-size:2;}

.bcode-edit:empty:focus::before{content:attr(data-ph);color:#707785;pointer-events:none;}

.bbullet{display:flex;align-items:flex-start;gap:10px;}

.bbullet-dot{width:5px;height:5px;border-radius:50%;background:var(--text2);margin-top:10px;flex-shrink:0;}

.bbullet-text{font-size:15px;line-height:1.75;flex:1;min-height:26px;}

.btodo{display:flex;align-items:flex-start;gap:10px;}

.btodo-check{width:16px;height:16px;border:1.5px solid var(--border2);border-radius:3px;margin-top:5px;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;}

.btodo-check.done{background:var(--accent);border-color:var(--accent);}

.btodo-check.done::after{content:'✓';font-size:9px;color:#fff;font-weight:700;}

.btodo-text{font-size:15px;line-height:1.75;flex:1;min-height:26px;}

.btodo-text.struck{text-decoration:line-through;color:var(--text3);}

.bcallout{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;display:flex;gap:10px;}

.bcallout-icon{font-size:16px;flex-shrink:0;margin-top:2px;}

.bcallout-text{font-size:15px;line-height:1.75;flex:1;min-height:26px;}

.bdivider{border:none;border-top:1px solid var(--border2);width:100%;margin:8px 0;}

.bimg-wrap img{max-width:100%;border-radius:var(--radius-sm);}

.bimg-col-wrap{display:flex;gap:16px;align-items:flex-start;}

.bimg-col-img{flex-shrink:0;}

.bimg-col-txt{
  flex:1;min-width:0;font-size:15px;line-height:1.75;color:var(--text);
  outline:none;caret-color:var(--accent);padding:4px 0;min-height:80px;
  border-left:2px solid var(--border);padding-left:14px;
}

.bimg-col-txt:empty:focus::before{content:attr(data-ph);color:var(--text3);pointer-events:none;}

.bimg-toolbar{
  display:flex;align-items:center;gap:4px;flex-wrap:wrap;
  padding:6px 8px;background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--radius-sm);margin-bottom:8px;opacity:0;
  transition:opacity .15s;
}

.bimg-wrap:hover .bimg-toolbar{opacity:1;}

.bimg-toolbar-group{display:flex;align-items:center;gap:3px;}

.bimg-toolbar-sep{width:1px;height:16px;background:var(--border2);margin:0 3px;}

.bimg-cap{font-size:12px;color:var(--text3);margin-top:6px;outline:none;min-height:18px;}

.bimg-cap:empty:focus::before{content:attr(data-ph);color:var(--text3);pointer-events:none;}

.bimg-ph{border:2px dashed var(--border2);border-radius:var(--radius-sm);padding:28px;text-align:center;color:var(--text3);font-size:13px;cursor:pointer;transition:all .15s;}

.bimg-ph:hover,.drag-over-ph{border-color:var(--accent);color:var(--accent);background:var(--accent-soft);}

.drag-over-ph{border-style:solid !important;transform:scale(1.01);}

/* Full editor drag overlay */

.drag-over{outline:3px dashed var(--accent);outline-offset:-4px;background:rgba(124,106,255,0.04);}

.bvideo-ph{border:2px dashed var(--border2);border-radius:var(--radius-sm);padding:22px;text-align:center;}

.bvideo-inp{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;outline:none;font-family:'DM Sans',sans-serif;color:var(--text);margin-top:8px;}

.btable{border-collapse:collapse;width:100%;font-size:13px;}

.btable td{border:1px solid var(--border2);padding:7px 10px;outline:none;min-width:90px;caret-color:var(--accent);color:var(--text);}

.btable thead td{background:var(--surface2);font-weight:600;}

/* draw */

.draw-block{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}

.draw-tb{display:flex;gap:5px;padding:6px 10px;background:var(--surface2);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;}

.dbtn{padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);font-size:11px;cursor:pointer;color:var(--text2);font-family:'DM Sans',sans-serif;transition:all .12s;}

.dbtn:hover{background:var(--surface3);color:var(--text);}

.dbtn.active{background:var(--accent-soft);color:var(--accent2);border-color:var(--accent);}

.cswatch{width:16px;height:16px;border-radius:50%;border:2px solid transparent;cursor:pointer;flex-shrink:0;}

.cswatch.active{border-color:var(--text);transform:scale(1.25);}

.szslider{width:60px;accent-color:var(--accent);}

.draw-canvas{display:block;cursor:crosshair;touch-action:none;background:#fff;}

/* flowchart */

.flow-block{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}

.flow-tb{display:flex;gap:5px;padding:6px 10px;background:var(--surface2);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;}

.flow-canvas{position:relative;min-height:300px;background:#fff;background-image:radial-gradient(circle,#ddd 1px,transparent 1px);background-size:20px 20px;overflow:hidden;}

.fnode{position:absolute;min-width:100px;padding:8px 14px;border-radius:var(--radius-sm);border:2px solid;font-size:12px;font-weight:500;text-align:center;cursor:move;user-select:none;transition:box-shadow .15s;background:#fff;}

.fnode:hover{box-shadow:0 4px 14px rgba(0,0,0,.15);}

.fnode.sel{box-shadow:0 0 0 3px var(--accent);}

.fnode.t-rect{border-color:#5b4de8;color:#5b4de8;}

.fnode.t-round{border-color:#22c97e;color:#22c97e;border-radius:99px;}

.fnode.t-diamond{border-color:#f5a623;color:#f5a623;width:90px;height:90px;border-radius:4px;display:flex;align-items:center;justify-content:center;padding:0;transform:rotate(45deg);}

.fnode.t-diamond .flabel{transform:rotate(-45deg);display:block;font-size:10px;padding:0 4px;}

.fnode.t-circle{border-color:#ff5e5e;color:#ff5e5e;border-radius:50%;width:80px;height:80px;display:flex;align-items:center;justify-content:center;padding:0;}

.fnode .fndel{position:absolute;top:-7px;right:-7px;background:var(--red);color:#fff;border:none;border-radius:50%;width:14px;height:14px;font-size:9px;cursor:pointer;display:none;align-items:center;justify-content:center;}

.fnode:hover .fndel{display:flex;}

.fnode .fnconn{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:11px;height:11px;background:var(--accent);border-radius:50%;cursor:crosshair;display:none;border:2px solid #fff;}

.fnode:hover .fnconn{display:block;}

/* slash menu */

.slash-menu{position:fixed;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.3);width:250px;max-height:340px;overflow-y:auto;z-index:1000;padding:5px;}

.wiki-link{
  color:var(--blue);
  text-decoration:underline;
  text-underline-offset:2px;
  cursor:pointer;
}

.wiki-link:hover{ color:#7fb8ff; }

.sl-group{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:7px 9px 3px;}

.sl-item{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:var(--radius-sm);cursor:pointer;transition:all .1s;}

.sl-item:hover,.sl-item.focus{background:var(--accent-soft);}

.sl-icon{width:28px;height:28px;background:var(--surface2);border:1px solid var(--border);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}

.sl-name{font-size:13px;font-weight:500;color:var(--text);}

.sl-desc{font-size:11px;color:var(--text3);}

/* emoji picker */

.emoji-picker{position:fixed;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.3);padding:10px;z-index:1000;display:flex;flex-wrap:wrap;gap:3px;width:230px;max-height:180px;overflow-y:auto;}

.eopt{font-size:20px;cursor:pointer;padding:3px;border-radius:4px;line-height:1;}

.eopt:hover{background:var(--surface2);}

/* format bar */

.fmt-bar{position:fixed;background:rgba(18,18,24,.94);color:#fff;border-radius:10px;padding:4px 6px;display:none;gap:2px;z-index:500;box-shadow:0 10px 32px rgba(0,0,0,.38);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);}

.fmt-bar.show{display:flex;}

.fmtbtn{background:none;border:none;color:rgba(255,255,255,.84);cursor:pointer;padding:4px 7px;border-radius:6px;font-size:12px;font-family:'DM Sans',sans-serif;}

.fmtbtn:hover{background:rgba(255,255,255,.15);color:#fff;}

.fmt-sep{width:1px;background:rgba(255,255,255,.2);margin:2px 3px;flex-shrink:0;align-self:stretch;}

.fmt-label{font-size:11px;font-weight:700;color:rgba(255,255,255,.5);padding:0 2px;align-self:center;pointer-events:none;user-select:none;}

.fmt-color-btn{width:14px!important;height:14px!important;border-radius:3px!important;padding:0!important;flex-shrink:0;border:1.5px solid rgba(255,255,255,.3)!important;}

.fmt-color-btn:hover{transform:scale(1.25);border-color:#fff!important;}

.fmt-color-pop{position:fixed;z-index:501;background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:10px;min-width:260px;box-shadow:0 14px 38px rgba(0,0,0,.35);}

.fmt-pop-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}

.fmt-pop-head #fmt-pop-title{font-size:12px;font-weight:700;color:var(--text2);}

.fmt-pop-close{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;line-height:1;padding:2px 4px;border-radius:4px;}

.fmt-pop-close:hover{background:var(--surface2);color:var(--text);}

.fmt-pop-section{margin-top:8px;}

.fmt-pop-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;}

.fmt-pop-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;}

.fmt-pop-swatch{width:24px;height:24px;border-radius:7px;border:1px solid var(--border2);cursor:pointer;position:relative;}

.fmt-pop-swatch:hover{transform:translateY(-1px);}

.fmt-pop-swatch.fav::after{content:'★';position:absolute;right:2px;top:1px;font-size:9px;color:rgba(0,0,0,.65);text-shadow:0 1px 2px rgba(255,255,255,.5);}

.fmt-pop-custom{display:flex;align-items:center;gap:6px;}

.fmt-pop-custom input[type="color"]{width:34px;height:28px;border:none;background:none;padding:0;cursor:pointer;}

::-webkit-scrollbar{width:5px;}

::-webkit-scrollbar-track{background:transparent;}

::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:99px;}

/* ══════════════════════════════════════
   BASE DE CONHECIMENTO
══════════════════════════════════════ */

/* hub grid */

.kb-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:24px;flex-wrap:wrap;}

.kb-search{flex:1;min-width:180px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;color:var(--text);outline:none;font-family:'DM Sans',sans-serif;}

.kb-search:focus{border-color:var(--accent);}

.kb-search::placeholder{color:var(--text3);}

.kb-toolbar-modern{margin-bottom:14px;}

.kb-search-modern-wrap{
  width:100%;
  position:relative;
  display:flex;
  align-items:center;
  border:1px solid rgba(124,106,255,.28);
  border-radius:14px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0)),
    linear-gradient(135deg,rgba(124,106,255,.1),rgba(46,213,255,.07));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03), 0 8px 24px rgba(0,0,0,.22);
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.kb-search-modern-wrap:focus-within{
  border-color:rgba(124,106,255,.62);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04), 0 10px 28px rgba(0,0,0,.28), 0 0 0 3px rgba(124,106,255,.14);
  transform:translateY(-1px);
}

.kb-search-modern-ico{
  width:16px;
  height:16px;
  color:#b6aaff;
  margin-left:12px;
  flex-shrink:0;
  opacity:.95;
}

.kb-search-modern{
  border:none;
  background:transparent;
  border-radius:14px;
  min-height:44px;
  padding:10px 14px 10px 10px;
}

.kb-search-modern:focus{border:none;}

.kb-search-modern::placeholder{color:#9c94c8;}

.kb-tags{display:flex;gap:6px;flex-wrap:wrap;}

.kb-tag{padding:5px 12px;border-radius:99px;font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:none;color:var(--text2);transition:all .15s;font-family:'DM Sans',sans-serif;}

.kb-tag:hover{border-color:var(--accent);color:var(--accent2);}

.kb-tag.active{background:var(--accent-soft);color:var(--accent2);border-color:var(--accent);}

/* materia grid */

.materia-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:32px;}

.materia-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .2s;position:relative;}

.materia-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3);}

.materia-card-actions{position:absolute;top:8px;right:8px;display:flex;gap:6px;opacity:0;pointer-events:none;transition:opacity .15s;z-index:2;}

.materia-card:hover .materia-card-actions{opacity:1;pointer-events:auto;}

.materia-card-action{width:28px;height:28px;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:rgba(12,12,15,.66);color:#fff;font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(6px);transition:transform .15s,background .15s,border-color .15s;}

.materia-card-action:hover{transform:translateY(-1px);background:rgba(12,12,15,.82);border-color:rgba(255,255,255,.3);}

.materia-card-action.danger:hover{border-color:rgba(255,97,115,.65);color:#ffb3bc;}

.materia-cover{height:120px;background:var(--gradient-cover);position:relative;overflow:hidden;flex-shrink:0;}

.materia-cover img{width:100%;height:100%;object-fit:cover;}

.materia-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:40px;}

.materia-body{padding:14px;}

.materia-emoji{font-size:18px;margin-bottom:4px;}

.materia-name{font-size:15px;font-weight:600;color:var(--text);}

.materia-meta{display:flex;align-items:center;gap:6px;margin-top:6px;flex-wrap:wrap;}

.materia-badge{font-size:10px;padding:2px 7px;border-radius:99px;font-weight:500;}

.materia-count{font-size:11px;color:var(--text3);}

.framework-card-foot{margin-top:8px;font-size:11px;color:var(--text3);}

.materia-add{border:2px dashed var(--border2);background:none;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text3);min-height:180px;}

.materia-add:hover{border-color:var(--accent);color:var(--accent);}

@media (hover:none){
  .materia-card-actions{opacity:1;pointer-events:auto;}
}

.kb-framework-card-menu{
  position:fixed;
  z-index:1400;
  min-width:160px;
  padding:6px;
  border:1px solid var(--border2);
  border-radius:10px;
  background:var(--surface);
  box-shadow:0 12px 30px rgba(0,0,0,.35);
}

.kb-framework-card-menu button{
  width:100%;
  border:none;
  background:none;
  color:var(--text);
  text-align:left;
  padding:8px 9px;
  border-radius:8px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
}

.kb-framework-card-menu button:hover{
  background:var(--surface2);
}

.kb-framework-card-menu button.danger{
  color:#ff9aa8;
}

.kb-framework-card-menu button.danger:hover{
  background:rgba(255,90,120,.12);
}

/* modulo list */

.kb-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:13px;color:var(--text3);}

.kb-breadcrumb span{cursor:pointer;transition:color .15s;}

.kb-breadcrumb span:hover{color:var(--accent2);}

.kb-breadcrumb .sep{color:var(--text3);}

.kb-breadcrumb .cur{color:var(--text);font-weight:500;cursor:default;}

.modulo-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}

.modulo-item{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;}

.modulo-item:hover{border-color:var(--border2);background:var(--surface2);}

.modulo-icon{font-size:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface2);border-radius:var(--radius-sm);}

.modulo-name{font-size:14px;font-weight:500;flex:1;}

.modulo-count{font-size:11px;color:var(--text3);}

.modulo-arrow{color:var(--text3);font-size:16px;}

/* view toggle */

.kb-view-toggle{display:flex;gap:2px;background:var(--surface2);border-radius:8px;padding:3px;flex-shrink:0;}

.kb-view-btn{width:30px;height:30px;border:none;background:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:all .15s;}

.kb-view-btn svg{width:14px;height:14px;}

.kb-view-btn:hover{color:var(--text2);}

.kb-view-btn.active{background:var(--surface);color:var(--accent2);box-shadow:0 1px 4px rgba(0,0,0,.18);}

/* filter row */

.kb-filter-row{display:flex;flex-direction:column;gap:8px;}

.kb-status-filters{border-top:1px solid var(--border);padding-top:8px;}

/* materia list view */

.materia-list{display:flex;flex-direction:column;gap:8px;margin-bottom:32px;}

.materia-list-item{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;}

.materia-list-item:hover{border-color:var(--accent);background:var(--surface2);}

.mli-cover{width:48px;height:48px;border-radius:8px;overflow:hidden;flex-shrink:0;}

.mli-cover-img{width:100%;height:100%;object-fit:cover;}

.mli-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:22px;}

.mli-info{flex:1;min-width:0;}

.mli-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.mli-meta{font-size:11px;color:var(--text3);margin-top:2px;}

.mli-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap;}

.mli-progress{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;width:56px;}

.mli-progress-bar{width:100%;height:4px;background:var(--surface3);border-radius:99px;overflow:hidden;}

.mli-progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .3s;}

.mli-progress-label{font-size:10px;color:var(--text3);}

.mli-actions{display:flex;gap:4px;opacity:0;pointer-events:none;transition:opacity .15s;}

.materia-list-item:hover .mli-actions{opacity:1;pointer-events:auto;}

.mli-arrow{color:var(--text3);font-size:16px;flex-shrink:0;}

/* modulo card grid */

.modulo-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px;}

.modulo-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 16px;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;gap:6px;}

.modulo-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.25);}

.modulo-card-icon{font-size:26px;}

.modulo-card-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.3;}

.modulo-card-count{font-size:11px;color:var(--text3);}

.modulo-card-del{position:absolute;top:8px;right:8px;opacity:0;pointer-events:none;transition:opacity .15s;}

.modulo-card:hover .modulo-card-del{opacity:1;pointer-events:auto;}

/* conteudo list */

.conteudo-grid{display:flex;flex-direction:column;gap:6px;}

.conteudo-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;}

.conteudo-item:hover{border-color:var(--border2);background:var(--surface2);}

.conteudo-emoji{font-size:16px;width:28px;text-align:center;}

.conteudo-name{font-size:14px;font-weight:500;flex:1;}

.conteudo-tags{display:flex;gap:5px;}

.ctag{font-size:10px;padding:2px 7px;border-radius:99px;font-weight:500;}

.ctag-backend{background:var(--blue-soft);color:var(--blue);}

.ctag-logica{background:var(--accent-soft);color:var(--accent2);}

.ctag-projeto{background:var(--green-soft);color:var(--green);}

.ctag-teoria{background:var(--amber-soft);color:var(--amber);}

.ctag-pratica{background:var(--red-soft);color:var(--red);}

.ctag-default{background:var(--surface3);color:var(--text2);}

.conteudo-date{font-size:11px;color:var(--text3);}

/* conteudo card grid */

.conteudo-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:24px;}

.conteudo-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 14px 10px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:6px;position:relative;}

.conteudo-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.22);}

.conteudo-card-emoji{font-size:22px;}

.conteudo-card-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;flex:1;}

.conteudo-card-tags{display:flex;gap:4px;flex-wrap:wrap;}

.conteudo-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:4px;}

.conteudo-card-status{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text3);}

/* viewer — página de estudo */

.kbv-wrap{max-width:1020px;margin:0 auto;padding-bottom:80px;transition:max-width .2s ease;}

.kbv-wrap.ne-full-width{max-width:none;}

.kbv-header{margin-bottom:28px;}

.kbv-emoji{font-size:52px;margin-bottom:8px;}

.kbv-title{font-family:'Lora',serif;font-size:34px;font-weight:600;color:var(--text);line-height:1.2;}

.kbv-meta{display:flex;gap:10px;align-items:center;margin-top:10px;flex-wrap:wrap;}

.kbv-section{margin-bottom:24px;}

.kbv-section-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);}

.kbv-section-icon{font-size:18px;}

.kbv-section-title{font-size:13px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;}

.kbv-text{font-size:15px;line-height:1.75;color:var(--text);background:none;border:none;width:100%;resize:none;font-family:'DM Sans',sans-serif;outline:none;caret-color:var(--accent);}

.kbv-text::placeholder{color:var(--text3);}

.kbv-code{font-family:'DM Mono',monospace;font-size:13px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;width:100%;resize:vertical;min-height:100px;color:var(--blue);outline:none;caret-color:var(--accent);}

.kbv-code::placeholder{color:var(--text3);}

.kbv-link-list{display:flex;flex-direction:column;gap:6px;}

.kbv-link-item{display:flex;align-items:center;gap:8px;}

.kbv-link-inp{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 10px;font-size:13px;color:var(--text);outline:none;font-family:'DM Sans',sans-serif;}

.kbv-link-inp:focus{border-color:var(--accent);}

.kbv-add-link{background:none;border:1px dashed var(--border2);color:var(--text3);border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;}

.kbv-add-link:hover{border-color:var(--accent);color:var(--accent);}

.kbv-video-inp{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;color:var(--text);outline:none;font-family:'DM Sans',sans-serif;margin-bottom:8px;}

.kbv-video-inp:focus{border-color:var(--accent);}

.kbv-video-frame{width:100%;height:300px;border:none;border-radius:var(--radius-sm);}

.kbv-exercises{display:flex;flex-direction:column;gap:6px;}

.kbv-ex-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--surface2);border-radius:var(--radius-sm);}

.kbv-ex-check{width:16px;height:16px;border:1.5px solid var(--border2);border-radius:3px;cursor:pointer;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all .15s;}

.kbv-ex-check.done{background:var(--accent);border-color:var(--accent);}

.kbv-ex-check.done::after{content:'✓';font-size:9px;color:#fff;font-weight:700;}

.kbv-ex-text{flex:1;font-size:14px;background:none;border:none;outline:none;color:var(--text);font-family:'DM Sans',sans-serif;caret-color:var(--accent);}

.kbv-ex-text::placeholder{color:var(--text3);}

.kbv-status{display:flex;gap:8px;align-items:center;}

.kbv-status-btn{padding:5px 12px;border-radius:99px;font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:none;color:var(--text2);transition:all .15s;font-family:'DM Sans',sans-serif;}

.kbv-status-btn.active{border-color:var(--green);color:var(--green);background:var(--green-soft);}

.kbv-status-btn.active-studying{border-color:var(--amber);color:var(--amber);background:var(--amber-soft);}

.kbv-status-btn.active-review{border-color:var(--blue);color:var(--blue);background:var(--blue-soft);}

.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:4px;}

.sd-done{background:var(--green);}

.sd-studying{background:var(--amber);}

.sd-review{background:var(--blue);}

.sd-new{background:var(--text3);}

/* ── ICONS ── */

.nav-icon { display:flex; align-items:center; justify-content:center; width:20px; height:20px; flex-shrink:0; }

.nav-icon svg { width:16px; height:16px; stroke:currentColor; flex-shrink:0; }

.nav-icon i { font-size:16px; line-height:1; }

.nav-icon .material-icons-round { font-size:18px; line-height:1; }

/* icon size helpers */

.ic-sm svg, .ic-sm i, .ic-sm .material-icons-round { width:14px; height:14px; font-size:14px; }

.ic-md svg, .ic-md i, .ic-md .material-icons-round { width:18px; height:18px; font-size:18px; }

.ic-lg svg, .ic-lg i, .ic-lg .material-icons-round { width:22px; height:22px; font-size:22px; }

/* page header icons */

.page-title-row { display:flex; align-items:center; gap:10px; }

.page-title-row svg { width:24px; height:24px; stroke:var(--accent2); }

.page-title-row i { font-size:22px; color:var(--accent2); }

.page-title-row .material-icons-round { font-size:24px; color:var(--accent2); }

/* button icons */

.btn svg { width:14px; height:14px; stroke:currentColor; }

.btn i { font-size:13px; }

/* stat icons */

.stat-icon { font-size:20px; margin-bottom:6px; display:flex; align-items:center; }

.stat-icon svg { width:20px; height:20px; }

.stat-icon i { font-size:20px; }

.stat-icon .material-icons-round { font-size:20px; }

/* KB tabs */

.kbv-tabs{display:flex;gap:4px;margin:20px 0 0;border-bottom:1px solid var(--border);padding-bottom:0;}

.kbv-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;border-radius:var(--radius-sm) var(--radius-sm) 0 0;}

.kbv-tab:hover{color:var(--text);background:var(--surface2);}

.kbv-tab.active{color:var(--accent2);border-bottom-color:var(--accent);}

.kbv-tab-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:600;border-radius:99px;padding:1px 6px;}

.kbv-caderno-toolbar{display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:12px;}

.kbv-caderno-blocks{min-height:200px;padding-bottom:60px;}

/* Recent notes */

.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-top:16px;}

.recent-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;cursor:pointer;transition:all .15s;}

.recent-card:hover{border-color:var(--border2);background:var(--surface2);transform:translateY(-1px);}

.recent-card-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.recent-card-meta{font-size:11px;color:var(--text3);margin-top:4px;}

.recent-card-preview{font-size:12px;color:var(--text2);margin-top:6px;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ══ LISTA DE COMPRAS ══ */

.shop-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px;}

.shop-lists-nav{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:24px;}

.shop-list-tab{padding:7px 16px;border-radius:99px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:none;color:var(--text2);transition:all .15s;font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:6px;}

.shop-list-tab:hover{background:var(--surface2);color:var(--text);}

.shop-list-tab.active{background:var(--green-soft);color:var(--green);border-color:var(--green);}

.shop-list-tab .tab-count{font-size:10px;background:var(--surface3);padding:1px 6px;border-radius:99px;}

.shop-list-tab.active .tab-count{background:rgba(34,201,126,.25);}

/* Add item bar */

.shop-add-bar{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;}

.shop-inp{flex:1;min-width:160px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;color:var(--text);outline:none;font-family:'DM Sans',sans-serif;transition:border .15s;}

.shop-inp:focus{border-color:var(--accent);}

.shop-inp::placeholder{color:var(--text3);}

.shop-cat-sel{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 10px;font-size:13px;color:var(--text);outline:none;font-family:'DM Sans',sans-serif;cursor:pointer;}

.shop-cat-sel option{background:var(--surface2);}

.shop-qty-inp{width:72px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 8px;font-size:13px;color:var(--text);outline:none;font-family:'DM Sans',sans-serif;text-align:center;}

/* Progress bar */

.shop-progress-wrap{margin-bottom:20px;}

.shop-progress-label{display:flex;justify-content:space-between;font-size:12px;color:var(--text3);margin-bottom:6px;}

.shop-progress-label span{color:var(--green);font-weight:500;}

/* Category groups */

.shop-group{margin-bottom:20px;}

.shop-group-label{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;padding:4px 0;border-bottom:1px solid var(--border);}

.shop-group-icon{font-size:15px;}

/* Items */

.shop-item{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;transition:all .15s;position:relative;}

.shop-item:hover{border-color:var(--border2);background:var(--surface2);}

.shop-item.checked{opacity:.45;}

.shop-item.checked .shop-item-name{text-decoration:line-through;}

.shop-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;}

.shop-check:hover{border-color:var(--green);}

.shop-check.on{background:var(--green);border-color:var(--green);}

.shop-check.on::after{content:'✓';font-size:11px;color:#fff;font-weight:700;}

.shop-item-name{flex:1;font-size:14px;font-weight:500;color:var(--text);cursor:text;outline:none;}

.shop-item-name:focus{background:var(--surface3);border-radius:4px;padding:2px 4px;}

.shop-item-qty{font-size:12px;color:var(--text3);background:var(--surface2);padding:2px 8px;border-radius:99px;cursor:pointer;}

.shop-item-qty:hover{background:var(--surface3);color:var(--text);}

.shop-item-cat{font-size:10px;padding:2px 7px;border-radius:99px;font-weight:500;}

.shop-item-price{font-size:12px;color:var(--text2);cursor:text;outline:none;min-width:48px;text-align:right;}

.shop-item-price::placeholder{color:var(--text3);}

.shop-item-del{opacity:0;background:none;border:none;color:var(--text3);cursor:pointer;font-size:13px;padding:2px 5px;border-radius:4px;transition:all .15s;}

.shop-item:hover .shop-item-del{opacity:1;}

.shop-item-del:hover{color:var(--red);background:var(--red-soft);}

/* Share modal */

.shop-share-box{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:12px;font-size:12px;color:var(--text2);word-break:break-all;margin:10px 0;font-family:'DM Mono',monospace;max-height:120px;overflow-y:auto;}

.shop-total{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface2);border-radius:var(--radius-sm);margin-top:12px;font-size:13px;}

.shop-total-val{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--green);}

/* Category color dots */

.ccat-hortifruti{background:rgba(34,201,126,.15);color:var(--green);}

.ccat-carnes{background:rgba(255,94,94,.13);color:var(--red);}

.ccat-limpeza{background:rgba(79,163,255,.12);color:var(--blue);}

.ccat-higiene{background:rgba(124,106,255,.15);color:var(--accent2);}

.ccat-laticinios{background:rgba(245,166,35,.13);color:var(--amber);}

.ccat-bebidas{background:rgba(79,163,255,.18);color:var(--blue);}

.ccat-mercearia{background:rgba(150,150,150,.15);color:var(--text2);}

.ccat-padaria{background:rgba(245,166,35,.2);color:var(--amber);}

.ccat-congelados{background:rgba(79,163,255,.2);color:var(--blue);}

.ccat-outros{background:var(--surface3);color:var(--text2);}

/* ── FC2 Canvas Livre ── */

.fc2-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;user-select:none;}

.fc2-toolbar{display:flex;align-items:center;gap:3px;padding:6px 10px;background:var(--surface2);border-bottom:1px solid var(--border);flex-wrap:wrap;}

.fc2-tool-group{display:flex;align-items:center;gap:3px;}

.fc2-sep{width:1px;height:18px;background:var(--border2);margin:0 4px;flex-shrink:0;}

.fc2-btn{padding:5px 7px;border-radius:var(--radius-sm);border:1px solid transparent;background:none;color:var(--text2);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:500;transition:all .12s;display:flex;align-items:center;gap:4px;white-space:nowrap;}

.fc2-btn svg{width:14px;height:14px;stroke:currentColor;}

.fc2-btn:hover{background:var(--surface3);color:var(--text);}

.fc2-btn.active{background:var(--accent-soft);color:var(--accent2);border-color:var(--accent);}

.fc2-color{width:16px;height:16px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .12s;flex-shrink:0;}

.fc2-color.active{border-color:var(--text);transform:scale(1.3);}

.fc2-color:hover{transform:scale(1.15);}

.fc2-svg{display:block;cursor:crosshair;}

.fc2-canvas-wrap{border-bottom-left-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm);}

.fc2-sel-box{pointer-events:none;}

/* ── Figma Embed Block ── */

.figma-block{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--surface);}

.figma-block-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface2);border-bottom:1px solid var(--border);}

.figma-ph{border:2px dashed var(--border2);border-radius:var(--radius-sm);padding:32px 24px;text-align:center;background:var(--surface);}

.figma-ph:hover{border-color:#7c6aff;background:rgba(124,106,255,0.04);}

/* ══ MINHA MÍDIA ══ */

.media-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px;}

.media-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}

/* Grid de cards */

.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;}

/* Card */

.media-card{background:#101116;border:1px solid #1f2230;border-radius:14px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;min-height:320px;}

.media-card:hover{border-color:#373d57;transform:translateY(-4px) scale(1.01);box-shadow:0 14px 34px rgba(0,0,0,.35);}

.media-card-banner{height:110px;display:flex;align-items:center;justify-content:center;font-size:48px;position:relative;flex-shrink:0;}

.media-card-body{padding:12px;flex:1;display:flex;flex-direction:column;gap:6px;}

.media-card-postered{aspect-ratio:auto;min-height:430px;justify-content:flex-start;background:#0d0e14;}

.media-card-poster{position:relative;inset:auto;width:100%;height:300px;object-fit:contain;background:#090b12;filter:saturate(1.06) contrast(1.03);}

.media-poster-fallback{position:relative;inset:auto;width:100%;height:300px;display:flex;align-items:center;justify-content:center;font-size:58px;}

.media-card-overlay{position:relative;z-index:2;background:#101523;padding:12px 12px 13px;flex:1;border-top:1px solid rgba(255,255,255,.08);}

.media-card-name{font-size:14px;font-weight:700;color:#fff;line-height:1.3;text-shadow:0 2px 6px rgba(0,0,0,.45);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

.media-card-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}

.media-type-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em;}

.media-type-filme{background:rgba(79,163,255,.15);color:#4fa3ff;}

.media-type-série{background:rgba(124,106,255,.15);color:#7c6aff;}

.media-type-jogo{background:rgba(34,201,126,.15);color:#22c97e;}

.media-status-badge{font-size:10px;padding:2px 7px;border-radius:99px;font-weight:500;}

.media-status-quero{background:rgba(245,166,35,.15);color:#f5a623;}

.media-status-consumindo{background:rgba(79,163,255,.18);color:#4fa3ff;}

.media-status-finalizado{background:rgba(34,201,126,.15);color:#22c97e;}

.media-stars{display:flex;gap:4px;margin-top:8px;padding-top:2px;flex-wrap:wrap;}

.media-star{font-size:20px;cursor:pointer;opacity:.82;color:#e8ecff;transition:transform .12s,color .12s,opacity .12s;}

.media-star.on{opacity:1;color:#ffd75a;text-shadow:0 0 8px rgba(255,210,74,.45),0 0 2px rgba(255,255,255,.7);}

.media-star:hover{transform:scale(1.18);}

.media-card-del{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:11px;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1;z-index:3;}

.media-card:hover .media-card-del{display:flex;}

/* Modal de adicionar/editar */

.media-modal-banner{height:80px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:48px;margin-bottom:16px;cursor:pointer;border:2px dashed var(--border2);transition:all .15s;}

.media-modal-banner:hover{border-color:var(--accent);}

/* Stats bar */

.media-stats{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;}

.media-stat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;display:flex;flex-direction:column;gap:2px;min-width:90px;}

.media-stat-val{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;color:var(--text);}

.media-stat-lbl{font-size:11px;color:var(--text3);}

/* Mídia — lista view */

.media-list{display:flex;flex-direction:column;gap:8px;}

.media-row{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;}

.media-row:hover{border-color:var(--border2);background:var(--surface2);}

.media-row-emoji{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}

.media-row-info{flex:1;min-width:0;}

.media-card-banner{font-size:48px;display:flex;align-items:center;justify-content:center;}

/* ══ FINANCEIRO ══ */

.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}

.fin-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px;}

@media(max-width:700px){.fin-grid,.fin-grid-3{grid-template-columns:1fr;}}

/* Resumo no topo */

.fin-summary{background:linear-gradient(135deg,#1a1d2e,#2a1a3e);border-radius:var(--radius);padding:24px;margin-bottom:24px;color:#fff;position:relative;overflow:hidden;}

.fin-summary::before{content:'';position:absolute;top:-40px;right:-40px;width:200px;height:200px;border-radius:50%;background:rgba(124,106,255,.15);}

.fin-summary-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;opacity:.6;margin-bottom:6px;}

.fin-summary-val{font-family:'Syne',sans-serif;font-size:36px;font-weight:700;line-height:1;}

.fin-summary-sub{font-size:12px;opacity:.6;margin-top:6px;}

.fin-summary-row{display:flex;gap:32px;margin-top:20px;flex-wrap:wrap;}

.fin-summary-item{display:flex;flex-direction:column;gap:3px;}

.fin-summary-item-lbl{font-size:11px;opacity:.55;}

.fin-summary-item-val{font-size:16px;font-weight:600;}

/* Seções */

.fin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;}

.fin-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}

.fin-section-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text);}

.fin-section-title span{font-size:18px;}

.fin-section-total{font-size:13px;font-weight:600;color:var(--text2);}

/* Linha de item */

.fin-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;transition:all .12s;}

.fin-item:hover{border-color:var(--border2);}

.fin-item-name{flex:1;font-size:13px;font-weight:500;color:var(--text);}

.fin-item-val{font-size:14px;font-weight:600;color:var(--text);font-family:'Syne',sans-serif;min-width:90px;text-align:right;}

.fin-item-tag{font-size:10px;padding:2px 7px;border-radius:99px;font-weight:500;flex-shrink:0;}

.fin-item-del{background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;opacity:0;transition:opacity .12s;padding:2px 5px;border-radius:4px;}

.fin-item:hover .fin-item-del{opacity:1;}

.fin-item-del:hover{color:var(--red);background:var(--red-soft);}

/* Add row inline */

.fin-add-row{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;}

.fin-inp{flex:1;min-width:120px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;color:var(--text);outline:none;font-family:'DM Sans',sans-serif;}

.fin-inp:focus{border-color:var(--accent);}

.fin-inp::placeholder{color:var(--text3);}

/* Barra de progresso de orçamento */

.fin-bar-wrap{margin-top:6px;}

.fin-bar{height:6px;background:var(--surface3);border-radius:99px;overflow:hidden;margin-top:4px;}

.fin-bar-fill{height:100%;border-radius:99px;transition:width .3s;}

/* Tags por categoria */

.fin-tag-despesa{background:rgba(255,94,94,.12);color:var(--red);}

.fin-tag-fixo{background:rgba(245,166,35,.12);color:var(--amber);}

.fin-tag-cartao{background:rgba(124,106,255,.12);color:var(--accent2);}

.fin-tag-emprestimo{background:rgba(255,94,94,.18);color:var(--red);}

.fin-tag-poupanca{background:rgba(34,201,126,.12);color:var(--green);}

.fin-tag-variavel{background:rgba(79,163,255,.12);color:var(--blue);}

/* Salário big input */

.fin-salary-wrap{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);}

.fin-salary-inp{flex:1;background:none;border:none;font-family:'Syne',sans-serif;font-size:28px;font-weight:700;color:var(--text);outline:none;}

.fin-salary-inp::placeholder{color:var(--text3);}

/* ══ PAINEL ══ */

.painel-profile-card{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:20px;background:var(--surface);border:1px solid var(--border);}

.painel-cover{height:120px;background:var(--gradient-cover);cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;}

.painel-cover img{width:100%;height:100%;object-fit:cover;}

.painel-cover-edit{position:absolute;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:500;gap:6px;}

.painel-cover:hover .painel-cover-edit{display:flex;}

.painel-profile-body{padding:0 20px 20px;position:relative;}

.painel-avatar-wrap{position:absolute;top:-36px;left:20px;width:72px;height:72px;border-radius:50%;border:3px solid var(--surface);background:var(--surface2);overflow:hidden;cursor:pointer;}

.painel-avatar-wrap img{width:100%;height:100%;object-fit:cover;}

.painel-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;background:var(--gradient-cover);}

.painel-profile-info{padding-top:44px;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:10px;}

.painel-name{font-size:18px;font-weight:700;color:var(--text);}

.painel-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px;}

.painel-tag{font-size:11px;padding:2px 8px;border-radius:99px;background:var(--surface2);color:var(--text2);border:1px solid var(--border);}

/* Grid de módulos */

.painel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;}

.painel-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .18s;cursor:pointer;}

.painel-widget:hover{border-color:var(--border2);box-shadow:0 4px 16px rgba(0,0,0,.08);transform:translateY(-1px);}

.painel-widget-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border);}

.painel-widget-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--text);letter-spacing:.01em;}

.painel-widget-body{padding:14px 16px;}

.painel-widget-goto{color:var(--text3);opacity:0;transition:opacity .18s;}

.painel-widget:hover .painel-widget-goto{opacity:1;}

/* Atalhos de módulos */

.painel-shortcuts{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;margin-bottom:24px;}

.painel-shortcut{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 10px 14px;cursor:pointer;transition:transform .16s,box-shadow .16s,border-color .16s;display:flex;flex-direction:column;align-items:center;gap:12px;position:relative;}

.painel-shortcut:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.12);border-color:var(--border2);}

.painel-shortcut:active{transform:translateY(-1px);}

.painel-shortcut-icon-wrap{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}

.painel-shortcut-icon-wrap svg{width:24px;height:24px;stroke-width:1.7;}

.painel-shortcut-label{font-size:11px;font-weight:600;color:var(--text2);text-align:center;line-height:1.3;letter-spacing:.01em;}

/* Edit profile modal */

.profile-edit-field{margin-bottom:12px;}

.profile-edit-label{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;}

/* ══ MUSIC PLAYER ══ */

.music-player{
  position:fixed;bottom:0;left:var(--sw);right:0;
  background:var(--surface);border-top:1px solid var(--border);
  padding:10px 20px;display:none;align-items:center;gap:14px;
  z-index:50;backdrop-filter:blur(12px);
  transition:transform .25s;
}

.music-player.active{display:flex;}

.music-player-thumb{width:38px;height:38px;border-radius:8px;background:var(--gradient-cover);
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}

.music-player-info{flex:1;min-width:0;}

.music-player-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.music-player-sub{font-size:11px;color:var(--text3);}

.music-player-controls{display:flex;align-items:center;gap:8px;}

.music-btn{background:none;border:none;cursor:pointer;color:var(--text2);padding:6px;border-radius:50%;transition:all .12s;display:flex;align-items:center;justify-content:center;}

.music-btn:hover{background:var(--surface2);color:var(--text);}

.music-btn.play-btn{width:36px;height:36px;background:var(--accent2);color:#fff;border-radius:50%;}

.music-btn.play-btn:hover{background:var(--accent);transform:scale(1.06);}

.music-progress-wrap{flex:1;display:flex;align-items:center;gap:8px;max-width:360px;}

.music-time{font-size:10px;color:var(--text3);min-width:32px;text-align:center;font-family:'DM Mono',monospace;}

.music-progress{flex:1;height:4px;background:var(--surface3);border-radius:99px;cursor:pointer;position:relative;}

.music-progress-fill{height:100%;background:var(--accent2);border-radius:99px;pointer-events:none;}

.music-progress:hover{height:6px;}

.music-volume{display:flex;align-items:center;gap:6px;}

.music-vol-slider{width:64px;accent-color:var(--accent2);}

.music-close{background:none;border:none;cursor:pointer;color:var(--text3);padding:4px;font-size:14px;border-radius:4px;}

.music-close:hover{color:var(--text);}

/* ══ APP SHELL ══ */

#app-shell {
  display: none;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  flex-direction: row;
}

#app-shell.visible {
  display: flex !important;
}

/* Tabela de compras cartão */

.fin-row-del{opacity:0;transition:opacity .12s;}

tr:hover .fin-row-del{opacity:1 !important;}

/* ══ CONFIGURAÇÕES DE PÁGINA ══ */

.ne-settings-btn{
  margin-left:auto;background:none;border:none;cursor:pointer;
  color:var(--text3);padding:4px 8px;border-radius:var(--radius-sm);
  font-size:11px;font-family:'DM Sans',sans-serif;
  display:flex;align-items:center;gap:5px;transition:all .12s;
}

.ne-settings-btn:hover{background:var(--surface2);color:var(--text);}

.ne-page-top-actions{
  position:sticky;
  top:6px;
  z-index:16;
  display:flex;
  justify-content:flex-end;
  gap:8px;
  padding:6px 12px 0;
  pointer-events:none;
}

.ne-page-top-btn{
  pointer-events:auto;
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;
  border-radius:10px;
  border:1px solid var(--border2);
  background:rgba(32,32,32,.82);
  backdrop-filter:blur(6px);
  color:var(--text2);
  font-size:12px;font-weight:600;
  cursor:pointer;transition:all .15s;
}

.ne-page-top-btn:hover{color:var(--text);border-color:var(--accent2);background:var(--surface2);}

.ne-page-top-btn.accent{color:var(--accent2);border-color:rgba(124,106,255,.45);background:rgba(124,106,255,.12);}

.ne-settings-panel{
  position:fixed;top:0;right:0;width:280px;height:100vh;
  background:var(--surface);border-left:1px solid var(--border);
  z-index:200;display:none;flex-direction:column;
  box-shadow:-4px 0 20px rgba(0,0,0,.15);
}

.ne-settings-panel.open{display:flex;}

.ne-settings-header{
  padding:16px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}

.ne-settings-body{padding:16px 18px;overflow-y:auto;flex:1;}

.ne-settings-section{margin-bottom:20px;}

.ne-settings-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;}

/* Font picker */

.ne-font-opts{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;}

.ne-font-opt{
  padding:10px 6px;border:1px solid var(--border2);border-radius:var(--radius-sm);
  background:var(--surface2);cursor:pointer;text-align:center;transition:all .12s;
}

.ne-font-opt:hover{border-color:var(--accent);}

.ne-font-opt.active{border-color:var(--accent2);background:var(--accent-soft);}

.ne-font-opt-name{font-size:18px;font-weight:600;line-height:1;margin-bottom:4px;}

.ne-font-opt-label{font-size:10px;color:var(--text3);}

/* Toggle rows */

.ne-toggle-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;border-bottom:1px solid var(--border);
}

.ne-toggle-row:last-child{border-bottom:none;}

.ne-toggle-info{flex:1;}

.ne-toggle-title{font-size:13px;font-weight:500;color:var(--text);}

.ne-toggle-sub{font-size:11px;color:var(--text3);margin-top:1px;}

.ne-sw{
  width:40px;height:22px;border-radius:99px;border:none;cursor:pointer;
  position:relative;transition:background .2s;flex-shrink:0;
}

.ne-sw-thumb{
  width:16px;height:16px;border-radius:50%;background:#fff;
  position:absolute;top:3px;transition:left .15s;
  box-shadow:0 1px 3px rgba(0,0,0,.25);
}

/* Aplicar fonte na área de edição */

.ne-font-default .ne-title,
.ne-font-default .b-content *,
.ne-font-default [contenteditable]{
  font-family:'DM Sans',sans-serif;
}

.ne-font-serif .ne-title,
.ne-font-serif .b-content *,
.ne-font-serif [contenteditable]{
  font-family:'Lora',serif;
}

.ne-font-mono .ne-title,
.ne-font-mono .b-content *,
.ne-font-mono [contenteditable]{
  font-family:'DM Mono',monospace;
  font-size:.92em;
}

/* Largura completa */

.ne-full-width .ne-title-wrap,
.ne-full-width .blocks-wrap{
  padding-left:16px !important;
  padding-right:16px !important;
  max-width:none !important;
}

.ne-full-width .note-editor-toolbar{
  padding-left:16px !important;
  padding-right:16px !important;
}

.ne-full-width .ne-cover-btn{ left:16px; }

/* Texto pequeno */

.ne-small-text .b-content *,
.ne-small-text [contenteditable]{
  font-size:.875em;
}

.ne-small-text .ne-title{ font-size:26px; }

/* ══ TUTORIAIS ══ */

.tut-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:20px;}

.tut-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .18s;position:relative;}

.tut-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12);}

.tut-cover{height:100px;background:var(--gradient-cover);position:relative;display:flex;align-items:center;justify-content:center;font-size:40px;}

.tut-cover img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}

.tut-cover-emoji{position:relative;z-index:1;}

.tut-body{padding:14px;}

.tut-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.3;}

.tut-desc{font-size:12px;color:var(--text3);line-height:1.5;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

.tut-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}

.tut-tag{font-size:10px;padding:2px 7px;border-radius:99px;background:var(--surface2);color:var(--text3);}

.tut-status{font-size:10px;padding:2px 8px;border-radius:99px;font-weight:600;}

.tut-status.published{background:rgba(34,201,126,.15);color:#22c97e;}

.tut-status.draft{background:var(--surface2);color:var(--text3);}

.tut-views{font-size:10px;color:var(--text3);margin-left:auto;}

/* Editor de tutorial */

.tut-editor-wrap{display:flex;flex-direction:column;height:100%;}

.tut-editor-topbar{
  display:flex;align-items:center;gap:10px;padding:10px 48px;
  background:var(--surface);border-bottom:1px solid var(--border);
  flex-shrink:0;flex-wrap:wrap;
}

.tut-publish-btn{
  margin-left:auto;padding:6px 16px;border-radius:var(--radius-sm);
  border:none;cursor:pointer;font-size:12px;font-weight:600;
  font-family:'DM Sans',sans-serif;transition:all .15s;
}

.tut-publish-btn.published{background:rgba(34,201,126,.15);color:#22c97e;border:1px solid rgba(34,201,126,.3);}

.tut-publish-btn.draft{background:var(--accent2);color:#fff;}

/* View pública */

.tut-public-wrap{
  max-width:720px;margin:0 auto;padding:40px 24px 80px;
  font-family:'DM Sans',sans-serif;color:var(--text);
}

.tut-public-cover{width:100%;height:220px;border-radius:var(--radius);overflow:hidden;margin-bottom:32px;object-fit:cover;}

.tut-public-title{font-family:'Lora',serif;font-size:36px;font-weight:700;line-height:1.2;margin-bottom:12px;}

.tut-public-meta{font-size:12px;color:var(--text3);margin-bottom:32px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;}

.tut-comment-section{margin-top:48px;padding-top:32px;border-top:1px solid var(--border);}

.tut-comment-form{background:var(--surface2);border-radius:var(--radius);padding:20px;margin-bottom:24px;}

.tut-comment-item{padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;}

.tut-comment-author{font-size:13px;font-weight:600;margin-bottom:4px;}

.tut-comment-date{font-size:11px;color:var(--text3);margin-bottom:8px;}

.tut-comment-text{font-size:14px;line-height:1.6;color:var(--text2);}

/* Senha pública */

.tut-password-screen{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--bg);font-family:'DM Sans',sans-serif;
}

/* ══ FILE VIEWER ══ */

.fv-block{ position:relative; }

.fv-extract-popup{ font-family:'DM Sans',sans-serif; }

mark[data-fvhl]{ cursor:pointer; transition:opacity .1s; }

mark[data-fvhl]:hover{ opacity:.75; }

/* KB caderno — configurações de página */

/* Largura completa: sobrescreve o padding inline do kbv-area e do kbq-area */

.note-editor-area.ne-full-width { padding-left: 16px !important; padding-right: 16px !important; }

.ne-full-width .kbv-caderno-blocks { padding-left: 0 !important; padding-right: 0 !important; }

/* Fonte no caderno KB */

.ne-font-default .kbv-caderno-blocks [contenteditable] { font-family:'DM Sans',sans-serif; }

.ne-font-serif .kbv-caderno-blocks [contenteditable]   { font-family:'Lora',serif; }

.ne-font-mono .kbv-caderno-blocks [contenteditable]    { font-family:'DM Mono',monospace; font-size:.92em; }

/* Texto pequeno */

.ne-small-text .kbv-caderno-blocks [contenteditable],
.ne-small-text .kbv-caderno-blocks .bp,
.ne-small-text .kbv-caderno-blocks .bh1,
.ne-small-text .kbv-caderno-blocks .bh2,
.ne-small-text .kbv-caderno-blocks .bh3 { font-size: .875em !important; }

/* ════════════════════════════════════════════
   RESPONSIVE — Mobile & Tablet
   Breakpoints:
   - Mobile:  < 640px
   - Tablet:  640px – 1024px
   - Desktop: > 1024px
════════════════════════════════════════════ */

/* ── Mobile nav bar (right side) ── */

.mob-nav{
  display:none;
  position:fixed;top:0;right:0;bottom:0;z-index:200;
  background:var(--surface);border-left:1px solid var(--border);
  padding:6px 4px;
  grid-template-columns:1fr;
  grid-template-rows:repeat(9,1fr);
  gap:0;
  width:56px;
}

.mob-nav-item{
  display:flex;flex-direction:column;align-items:center;
  gap:2px;padding:6px 2px;border:none;background:none;
  cursor:pointer;color:var(--text3);font-size:9px;
  font-family:'DM Sans',sans-serif;font-weight:500;
  border-radius:var(--radius-sm);transition:all .12s;
  position:relative;
}

.mob-nav-item svg{width:20px;height:20px;stroke:currentColor;flex-shrink:0;}

.mob-nav-item.active{color:var(--accent2);}

.mob-nav-item.active svg{stroke:var(--accent2);}

.mob-nav-item .mob-badge{
  position:absolute;top:4px;right:50%;transform:translateX(10px);
  background:var(--accent2);color:#fff;font-size:8px;font-weight:700;
  border-radius:99px;padding:1px 4px;min-width:14px;text-align:center;line-height:1.4;
}

/* Botão hamburguer (tablet) */

.mob-menu-btn{
  display:none;
  position:fixed;top:12px;left:12px;z-index:300;
  width:40px;height:40px;border-radius:var(--radius-sm);
  background:var(--surface);border:1px solid var(--border);
  cursor:pointer;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}

.mob-menu-btn svg{width:18px;height:18px;stroke:var(--text2);stroke-width:1.8;}

/* Overlay sidebar */

.sidebar-overlay{
  display:none;position:fixed;inset:0;z-index:149;
  background:rgba(0,0,0,.5);backdrop-filter:blur(2px);
}

.sidebar-overlay.open{display:block;}

/* ─── TABLET (640px – 1024px) ─── */

@media(max-width:1024px){
  .mob-menu-btn{display:flex;}

  .sidebar{
    width:240px;min-width:240px;
    transform:translateX(-100%);
    transition:transform .25s cubic-bezier(.4,0,.2,1);
    z-index:150;box-shadow:4px 0 24px rgba(0,0,0,.35);
    background:var(--surface);
  }
  .sidebar.mob-open{transform:translateX(0);}
  /* Restore full labels inside drawer */
  .sidebar.mob-open .logo{padding:20px 20px 16px;justify-content:flex-start;}
  .sidebar.mob-open .logo span{display:inline;}
  .sidebar.mob-open .logo::after{display:none;}
  .sidebar.mob-open .nav-section{display:block;font-size:10px;font-weight:500;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;padding:12px 10px 6px;}
  .sidebar.mob-open .nav-item{font-size:14px;justify-content:flex-start;padding:9px 12px;gap:10px;height:auto;border-left:none;border-radius:var(--radius-sm);}
  .sidebar.mob-open .nav-item.active{background:var(--accent-soft);color:var(--accent2);border-left:none;}
  .sidebar.mob-open .nav-item .badge{position:static;font-size:10px;padding:1px 6px;min-width:18px;}
  .sidebar.mob-open .note-nav-item{display:flex;align-items:center;gap:8px;padding:6px 10px 6px 24px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text3);transition:all .15s;margin-bottom:1px;border:none;background:none;width:100%;text-align:left;position:relative;}
  .sidebar.mob-open .sidebar-footer{padding:14px 20px;align-items:stretch;}
  .sidebar.mob-open .time-display{display:block;font-family:'Syne',sans-serif;font-size:22px;font-weight:600;color:var(--text);}
  .sidebar.mob-open .date-display{display:block;font-size:12px;color:var(--text3);margin-top:2px;}

  .main{margin-left:0;}

  .hub-page{padding:20px 20px 24px;}
  .hub-page.notes-full{height:calc(100vh - 0px);}

  .page-header{flex-wrap:wrap;gap:10px;}
  .page-title{font-size:22px;}

  /* Financeiro grid */
  .fin-grid{grid-template-columns:1fr 1fr;}
  .fin-card-full-grid{grid-template-columns:1fr;}

  /* Painel dashboard */
  .painel-shortcuts-grid{grid-template-columns:repeat(4,1fr);}
  .painel-widgets-grid{grid-template-columns:1fr 1fr;}

  /* Modals */
  .modal{margin:16px;max-width:calc(100vw - 32px) !important;}

  /* Settings panel */
  .ne-settings-panel{width:260px;}

  /* KB grid */
  .materia-grid{grid-template-columns:repeat(2,1fr);}
  .tut-grid{grid-template-columns:repeat(2,1fr);}

  /* Cards financeiro */
  .fin-card-grid{grid-template-columns:1fr;}
}

/* ─── MOBILE (< 640px) ─── */

@media(max-width:640px){
  /* Esconder sidebar, mostrar bottom nav */
  .sidebar{display:none;}
  .mob-menu-btn{display:none;}
  .mob-nav{display:grid;}
  .nb-topbar{display:none;}
  .nb-panel{display:none;}
  .main{padding-top:0;}

  .main{margin-left:0;padding-bottom:calc(64px + env(safe-area-inset-bottom));}
  .hub-page{padding:16px 14px 80px;}
  .hub-page.notes-full{height:calc(100vh - 68px);padding-bottom:0;}

  .page-header{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:18px;}
  .page-title{font-size:20px;}
  .page-header .btn{width:100%;justify-content:center;}

  /* Buttons full width em forms */
  .modal-footer{flex-direction:column;}
  .modal-footer .btn{width:100%;justify-content:center;}
  .modal{margin:8px;max-width:calc(100vw - 16px) !important;border-radius:14px;}

  /* Financeiro */
  .fin-grid,.fin-grid-3{grid-template-columns:1fr;}
  .fin-tabs{overflow-x:auto;flex-wrap:nowrap;gap:2px;padding-bottom:4px;}
  .fin-tab{white-space:nowrap;flex-shrink:0;font-size:11px;padding:6px 10px;}

  /* Despesas grid */
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important;}
  [style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr !important;}

  /* Painel */
  .painel-shortcuts-grid{grid-template-columns:repeat(4,1fr);}
  .painel-widgets-grid{grid-template-columns:1fr;}
  .painel-shortcut{padding:12px 8px;}
  .painel-shortcut-label{font-size:10px;}

  /* Tarefas */
  .task-item{flex-wrap:wrap;gap:6px;}

  /* Financeiro cartão */
  .fin-card-topbar{flex-wrap:wrap;}
  table{font-size:12px;}
  th,td{padding:6px 4px !important;}

  /* Minha mídia grid */
  .media-grid{grid-template-columns:repeat(2,1fr) !important;}

  /* KB */
  .materia-grid{grid-template-columns:1fr;}
  .kb-breadcrumb{font-size:12px;}
  .kbv-tabs{overflow-x:auto;}

  /* Tutoriais */
  .tut-grid{grid-template-columns:1fr;}
  .tut-editor-topbar{flex-wrap:wrap;padding:8px 10px;gap:6px;}
  .tut-editor-topbar .btn{font-size:11px;padding:4px 8px;}

  /* Editor blocos */
  .note-editor-toolbar{padding:6px 12px !important;gap:3px;}
  .ne-title-wrap{padding:20px 16px 8px !important;}
  .blocks-wrap{padding:8px 16px 60px !important;}
  .ne-title{font-size:24px !important;}
  .b-handle{display:none;width:0;}
  .kb-col-row{flex-direction:column;}
  .kb-col-resize{display:none;}
  .kb-col{padding:0;border-bottom:1px solid var(--border);}
  .kb-col:last-child{border-bottom:none;}

  /* File viewer */
  .fv-block{font-size:12px;}

  /* Settings panel */
  .ne-settings-panel{width:100%;border-left:none;border-top:1px solid var(--border);}

  /* Alarmes */
  .alarm-item{flex-wrap:wrap;}

  /* Lista de compras */
  .shop-list-grid{grid-template-columns:1fr;}

  /* Scroll horizontal em tabelas financeiras */
  .fin-section table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;}

  /* Quick notes nav */
  #quick-notes-nav .note-nav-item{padding-left:14px;}

  /* Tela cheia em mobile */
  .ne-settings-panel{top:0;height:100vh;border-radius:0;}

  /* Floating music player */
  #music-player-float{bottom:calc(68px + env(safe-area-inset-bottom));width:calc(100vw - 20px);left:10px;}

  /* IA action button above bottom nav */
  .ai-fab{
    right:12px;
    bottom:calc(84px + env(safe-area-inset-bottom));
    width:52px;
    height:52px;
    font-size:13px;
  }
}

/* ─── Safe area para iPhone X+ ─── */

@supports(padding-bottom: env(safe-area-inset-bottom)){
  .mob-nav{padding-bottom:calc(6px + env(safe-area-inset-bottom));}
  .main{padding-bottom:env(safe-area-inset-bottom);}
}

/* ========================================================
   GYM MODULE
   ======================================================== */

.gym-shell{display:flex;flex-direction:column;gap:14px;padding:6px 2px 14px;}

.gym-row-between{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}

.gym-row-between.top{margin-bottom:2px;}

.gym-tabbar{display:flex;gap:8px;flex-wrap:wrap;}

.gym-panel{display:flex;flex-direction:column;gap:14px;}

.gym-chip{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);padding:5px 9px;border-radius:999px;font-size:11px;font-weight:600;}

.gym-chip.ok{border-color:rgba(34,201,126,.45);color:#22c97e;background:rgba(34,201,126,.1);}

.gym-chip.warn{border-color:rgba(245,166,35,.45);color:#f5a623;background:rgba(245,166,35,.1);}

.gym-loading{padding:24px 12px;text-align:center;color:var(--text3);font-size:13px;}

.gym-kicker{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);font-weight:700;margin-bottom:6px;}

.gym-title{font-size:21px;font-weight:700;color:var(--text);line-height:1.2;}

.gym-title-sm{font-size:13px;font-weight:700;color:var(--text);line-height:1.3;}

.gym-sub{font-size:11px;color:var(--text3);}

.gym-muted{font-size:12px;color:var(--text3);}

.gym-empty{padding:20px;border:1px dashed var(--border2);border-radius:14px;background:var(--surface2);text-align:center;}

.gym-empty-title{font-size:14px;color:var(--text);font-weight:700;}

.gym-empty-sub{font-size:12px;color:var(--text3);margin-top:4px;}

.gym-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}

.gym-metrics.compact .gym-metric-card{padding:10px;}

.gym-metric-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:12px;min-height:72px;display:flex;flex-direction:column;justify-content:center;}

.gym-metric-value{font-size:20px;font-weight:800;color:var(--text);line-height:1;}

.gym-today-card,.gym-create-card,.gym-card,.gym-builder-card,.gym-lib-card,.gym-focus-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;}

.gym-day-list{display:flex;flex-direction:column;gap:8px;margin-top:12px;}

.gym-day-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);}

.gym-day-item-title{font-size:12px;color:var(--text);font-weight:600;}

.gym-day-item-meta{font-size:11px;color:var(--text3);margin-top:2px;}

.gym-settings-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}

.gym-setting{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--text2);}

.gym-setting-actions{display:flex;gap:6px;}

.gym-create-grid{display:grid;grid-template-columns:1fr;gap:12px;}

.gym-create-form,.gym-lib-form,.gym-builder-add{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px;}

.gym-builder-wrap,.gym-lib-grid,.gym-list{display:flex;flex-direction:column;gap:10px;}

.gym-builder-row,.gym-session-row,.gym-pr-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);}

.gym-builder-name{font-size:12px;font-weight:600;color:var(--text);}

.gym-builder-meta,.gym-lib-text{font-size:11px;color:var(--text3);}

.gym-builder-actions{display:flex;gap:6px;flex-wrap:wrap;}

.gym-lib-toolbar{display:flex;gap:8px;flex-wrap:wrap;}

.gym-link{font-size:11px;color:var(--accent2);text-decoration:none;margin-top:8px;display:inline-flex;}

.gym-two-col{display:grid;grid-template-columns:1fr;gap:12px;}

.gym-delta{font-size:11px;font-weight:700;}

.gym-delta.up{color:#22c97e;}

.gym-delta.down{color:#ff5e5e;}

.gym-focus-wrap{padding:8px 2px 20px;display:flex;flex-direction:column;gap:12px;max-width:780px;margin:0 auto;}

.gym-focus-top{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;}

.gym-focus-progress{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px;font-size:12px;color:var(--text2);}

.gym-focus-card h2{font-size:28px;line-height:1.05;color:var(--text);margin:3px 0 6px;}

.gym-focus-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0 8px;}

.gym-focus-grid label{font-size:11px;color:var(--text3);display:block;margin-bottom:4px;}

.gym-hints{display:grid;grid-template-columns:1fr;gap:6px;padding:9px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);font-size:11px;color:var(--text2);}

.gym-rest-box{margin-top:10px;padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);font-size:12px;color:var(--text2);}

.gym-focus-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px;}

.gym-flash{margin-top:10px;padding:8px;border-radius:9px;background:rgba(34,201,126,.12);border:1px solid rgba(34,201,126,.3);color:#22c97e;font-size:12px;font-weight:600;}

.gym-focus-card.flash{box-shadow:0 0 0 1px rgba(124,106,255,.4),0 0 24px rgba(124,106,255,.18);}

#hub-gym input,#hub-gym select,#hub-gym textarea{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:9px 10px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;}

#hub-gym textarea{min-height:74px;resize:vertical;}

#hub-gym input:focus,#hub-gym select:focus,#hub-gym textarea:focus{border-color:var(--accent2);box-shadow:0 0 0 3px rgba(124,106,255,.14);}

@media (min-width:760px){
  .gym-create-grid{grid-template-columns:1fr 1fr;}
  .gym-two-col{grid-template-columns:1fr 1fr;}
  .gym-focus-actions{grid-template-columns:1fr 1fr 1fr;}
  .gym-builder-add{grid-template-columns:1.2fr .5fr .5fr .6fr auto;align-items:center;}
}

/* ── CADERNO: modo pílulas inline ── */

.kbv-pilulas-mode{padding:8px 0 40px;}

.kbv-pilulas-topbar{display:flex;align-items:center;gap:8px;margin-bottom:10px;}

/* Botão modo futuro (Fluxograma) */

.kb-mode-future{opacity:.55;}

.kb-mode-future:hover{opacity:.85;}

.kb-mode-future.active{opacity:1;}

/* ── CADERNO: índice (TOC) ── */

.kbv-outer{position:relative;}

.kbv-toc{width:170px;position:fixed;top:80px;right:20px;max-height:calc(100vh - 120px);overflow-y:auto;padding:10px 12px;z-index:50;background:var(--bg);border-radius:8px;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.12);}

.kbv-toc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border);}

.kbv-toc-label{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;}

.kbv-toc-close{background:none;border:none;cursor:pointer;font-size:14px;color:var(--text3);padding:0 2px;line-height:1;border-radius:3px;}

.kbv-toc-close:hover{color:var(--text);background:var(--surface2);}

.kbv-toc-item{font-size:11px;color:var(--text3);line-height:1.4;padding:3px 5px;border-radius:4px;cursor:pointer;transition:all .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.kbv-toc-item:hover{color:var(--accent2);background:var(--accent-soft);}

.kbv-toc-h1{font-weight:600;color:var(--text2);font-size:11px;}

.kbv-toc-h2{padding-left:12px;font-size:10px;border-left:2px solid var(--border2);margin-left:4px;}

.kbv-toc-h2:hover{border-left-color:var(--accent);}

.ne-page-top-btn.active{color:var(--accent2);border-color:rgba(124,106,255,.45);background:rgba(124,106,255,.12);}

@media(max-width:900px){.kbv-toc{display:none!important;}}

/* ── CRONOGRAMA DE ESTUDOS (schedule block) ── */

.bschedule{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg);}

.bschedule-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface2);border-bottom:1px solid var(--border);}

.bschedule-hd-left{display:flex;align-items:center;gap:8px;}

.bschedule-hd-right{display:flex;gap:6px;}

.bschedule-icon{font-size:18px;}

.bschedule-title{font-weight:700;font-size:14px;color:var(--text);}

.bschedule-subject{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 10px;border-radius:20px;border:1px solid currentColor;opacity:.9;}

.bschedule-table-wrap{overflow-x:auto;padding:0;}

.sched-table{width:100%;border-collapse:collapse;font-size:12px;}

.sched-th-time{width:80px;padding:8px 10px;text-align:center;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--surface);}

.sched-th-day{padding:8px 6px;text-align:center;font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:var(--surface2);}

.sched-td-time{width:80px;padding:6px 8px;text-align:center;font-size:11px;font-weight:600;color:var(--text3);border-right:1px solid var(--border);border-bottom:1px solid var(--border2);line-height:1.3;white-space:nowrap;background:var(--surface);}

.sched-td-time small{display:block;font-size:10px;font-weight:400;color:var(--text3);opacity:.7;}

.sched-td-cell{padding:6px 8px;text-align:center;font-size:11px;font-weight:500;border-right:1px solid var(--border2);border-bottom:1px solid var(--border2);cursor:pointer;transition:filter .12s;vertical-align:middle;line-height:1.3;}

.sched-td-cell:hover{filter:brightness(1.08);}

.sched-td-all{padding:7px 12px;text-align:center;font-size:12px;font-weight:600;border-bottom:1px solid var(--border2);cursor:pointer;transition:filter .12s;}

.sched-td-all:hover{filter:brightness(1.08);}

.sched-td-empty{border-right:1px solid var(--border2);border-bottom:1px solid var(--border2);background:var(--surface);}

.sched-linked-dot{display:inline-block;margin-left:4px;font-size:8px;opacity:.7;vertical-align:middle;}

.sched-empty-state{padding:24px;text-align:center;color:var(--text3);font-size:13px;}

.sched-footer{padding:8px 14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;background:var(--surface);}

.sched-slot-row{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);margin-bottom:6px;flex-wrap:wrap;}

.sched-sr-time{font-size:11px;font-weight:600;color:var(--text3);min-width:90px;}

.sched-sr-label{flex:1;font-size:12px;font-weight:500;min-width:100px;}

.sched-sr-days{font-size:10px;color:var(--text3);}

.sched-sr-type{font-size:10px;font-weight:600;opacity:.8;}

.sched-day-chk{display:flex;align-items:center;gap:4px;font-size:12px;cursor:pointer;user-select:none;}

.sched-th-today{background:rgba(124,106,255,0.18)!important;color:var(--accent2)!important;font-weight:800!important;}

.sched-td-today{background:rgba(124,106,255,0.07)!important;}

/* ── ESTUDOS MODULE ── */

/* Shell & Tabs */

.est-shell{display:flex;flex-direction:column;height:100%;min-height:0;}

.est-tabbar{display:flex;gap:2px;padding:8px 12px 0;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto;}

.est-tab-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border:none;background:none;color:var(--text3);cursor:pointer;border-radius:8px 8px 0 0;font-size:12px;font-weight:600;white-space:nowrap;transition:color .15s,background .15s;border-bottom:2px solid transparent;margin-bottom:-1px;}

.est-tab-btn svg{width:14px;height:14px;flex-shrink:0;}

.est-tab-btn:hover{color:var(--text2);background:var(--surface2);}

.est-tab-btn.active{color:var(--accent2);border-bottom-color:var(--accent);background:var(--surface);}

.est-body{flex:1;overflow-y:auto;padding:20px 16px;}

/* Common */

.est-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px;}

.est-section-hd{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px;}

.est-section-hd svg{width:14px;height:14px;flex-shrink:0;opacity:.7;}

.est-hd-btn{margin-left:auto;background:none;border:none;color:var(--accent2);cursor:pointer;font-size:11px;padding:2px 6px;border-radius:5px;}

.est-hd-btn:hover{background:var(--accent-soft);}

.est-hd-sub{margin-left:auto;font-size:10px;color:var(--text3);font-weight:400;text-transform:none;letter-spacing:0;}

.est-section-title{font-size:13px;font-weight:700;color:var(--text2);}

.est-section-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}

.est-empty-sm{font-size:12px;color:var(--text3);padding:8px 0;text-align:center;}

.est-center-empty{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text3);font-size:13px;padding:40px 20px;text-align:center;}

.est-link{background:none;border:none;color:var(--accent2);cursor:pointer;font-size:12px;text-decoration:underline;}

.est-icon-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text2);cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center;transition:all .12s;}

.est-icon-btn:hover{border-color:var(--accent2);color:var(--accent2);}

.est-icon-del:hover{border-color:var(--red)!important;color:var(--red)!important;}

.est-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;transition:filter .15s;}

.est-btn-primary:hover{filter:brightness(1.1);}

.est-btn-ghost{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background:none;border:1px solid var(--border);color:var(--text2);border-radius:8px;cursor:pointer;font-size:12px;font-weight:500;transition:all .12s;}

.est-btn-ghost:hover{border-color:var(--accent2);color:var(--accent2);}

.est-btn-sm{padding:4px 10px!important;font-size:11px!important;}

.est-btn-round{border-radius:50%!important;width:40px;height:40px;padding:0!important;justify-content:center;}

.est-btn-lg{width:56px!important;height:56px!important;}

.est-prio-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}

.prio-high .est-prio-dot,.est-prio-dot.prio-high{background:var(--red);}

.prio-med .est-prio-dot,.est-prio-dot.prio-med{background:var(--amber);}

.prio-low .est-prio-dot,.est-prio-dot.prio-low{background:var(--green);}

.est-color-swatch{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .12s;}

.est-color-swatch:hover{transform:scale(1.15);}

.est-color-swatch.selected{border-color:#fff;box-shadow:0 0 0 2px var(--accent);}

/* Dashboard */

.est-dash{max-width:960px;margin:0 auto;}

.est-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;}

.est-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;}

.est-stat-icon svg{width:20px;height:20px;}

.est-stat-val{font-size:26px;font-weight:800;line-height:1;}

.est-stat-label{font-size:11px;font-weight:700;color:var(--text2);}

.est-stat-unit{font-size:10px;color:var(--text3);}

.est-dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}

.est-dash-left,.est-dash-right{display:flex;flex-direction:column;gap:12px;}

/* Timeline */

.est-timeline{display:flex;flex-direction:column;gap:6px;}

.est-tl-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-left:3px solid var(--border);background:var(--surface2);border-radius:0 8px 8px 0;}

.est-tl-time{font-size:11px;font-weight:700;color:var(--text3);white-space:nowrap;min-width:44px;}

.est-tl-info{flex:1;min-width:0;}

.est-tl-label{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.est-tl-sub{font-size:11px;color:var(--text3);}

/* Task rows */

.est-task-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border2);}

.est-task-row:last-child{border-bottom:none;}

.est-task-chk{width:16px;height:16px;border-radius:4px;border:2px solid var(--border2);flex-shrink:0;cursor:pointer;transition:all .12s;}

.est-task-chk:hover{border-color:var(--green);}

.est-task-lbl{flex:1;font-size:13px;font-weight:500;color:var(--text);}

/* Pomodoro quick */

.est-pom-quick{}

.est-pom-mini{text-align:center;padding:4px 0;}

.est-pom-mini-time{font-size:36px;font-weight:800;color:var(--accent2);letter-spacing:2px;}

/* Goal mini */

.est-goal-mini{margin-bottom:12px;}

.est-goal-mini:last-child{margin-bottom:0;}

.est-goal-mini-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;}

.est-goal-mini-title{font-size:13px;font-weight:600;color:var(--text);}

.est-goal-mini-pct{font-size:12px;font-weight:700;}

.est-goal-mini-meta{font-size:10px;color:var(--text3);margin-top:3px;}

/* Progress bars */

.est-prog-bar{height:5px;background:var(--surface3);border-radius:99px;overflow:hidden;}

.est-prog-bar-lg{height:8px;}

.est-prog-fill{height:100%;border-radius:99px;transition:width .5s;}

/* Habit mini */

.est-hab-mini{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border2);cursor:pointer;}

.est-hab-mini:last-child{border-bottom:none;}

.est-hab-mini.done .est-hab-mini-title{opacity:.6;}

.est-hab-mini-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;}

.est-hab-mini-title{flex:1;font-size:13px;font-weight:500;color:var(--text);}

.est-hab-mini-streak{font-size:10px;font-weight:700;color:var(--amber);}

/* Heatmap */

.est-heatmap{overflow-x:auto;padding-bottom:4px;}

.est-heatmap-grid{display:flex;gap:3px;}

.est-hm-col{display:flex;flex-direction:column;gap:3px;}

.est-hm-cell{width:13px;height:13px;border-radius:3px;}

.est-hm-empty{background:transparent;}

.est-hm-l0{background:var(--surface3);}

.est-hm-l1{background:rgba(124,106,255,.25);}

.est-hm-l2{background:rgba(124,106,255,.45);}

.est-hm-l3{background:rgba(124,106,255,.7);}

.est-hm-l4{background:var(--accent);}

.est-heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:8px;justify-content:flex-end;}

/* Rotina - week grid */

.est-rotina{display:flex;flex-direction:column;gap:16px;max-width:100%;}

.est-sched-block{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;}

.est-sched-block-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface2);border-bottom:1px solid var(--border);}

.est-sched-block-title{font-size:14px;font-weight:700;color:var(--text);}

.est-sched-block-sub{font-size:11px;font-weight:700;margin-top:2px;}

.est-week-grid{display:flex;overflow-x:auto;}

.est-week-time-col{flex-shrink:0;width:56px;}

.est-week-day-col{flex:1;min-width:80px;}

.est-week-day-col.today .est-week-day-hd{background:rgba(124,106,255,.18);color:var(--accent2);}

.est-week-day-hd{padding:8px 4px;text-align:center;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;background:var(--surface2);border-bottom:1px solid var(--border);letter-spacing:.05em;}

.est-week-cell{padding:8px 6px;border-bottom:1px solid var(--border2);border-right:1px solid var(--border2);min-height:44px;font-size:11px;}

.est-week-time{font-size:10px;font-weight:600;color:var(--text3);text-align:right;padding-right:8px;background:var(--surface);}

.est-week-empty{background:var(--surface);}

.est-week-slot{cursor:pointer;border-radius:4px;transition:filter .12s;border:1px solid transparent!important;}

.est-week-slot:hover{filter:brightness(1.1);}

.est-week-slot-label{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.est-week-slot-time{font-size:9px;color:var(--text3);margin-top:2px;}

/* Habitos */

.est-habitos{max-width:700px;margin:0 auto;}

.est-hab-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:8px;transition:border-color .15s;}

.est-hab-card.est-hab-done{border-color:var(--green);background:rgba(34,201,126,.04);}

.est-hab-card-left{flex-shrink:0;}

.est-hab-check{width:26px;height:26px;border-radius:50%;border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;}

.est-hab-check:hover{border-color:var(--green);}

.est-hab-card-body{flex:1;min-width:0;}

.est-hab-card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px;}

.est-hab-card-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;}

.est-streak-badge{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:700;}

.est-hab-total{font-size:11px;color:var(--text3);}

.est-week-dots{display:flex;gap:4px;}

.est-week-dot{width:24px;height:24px;border-radius:6px;background:var(--surface3);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1px;transition:all .15s;}

.est-week-dot.done{transform:scale(1.05);}

.est-week-dot-lbl{font-size:8px;color:var(--text3);font-weight:600;line-height:1;}

.est-hab-card-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0;}

/* Metas */

.est-metas{max-width:700px;margin:0 auto;}

.est-goal-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:8px;}

.est-goal-card-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px;}

.est-goal-title{font-size:14px;font-weight:700;color:var(--text);}

.est-goal-sub{font-size:11px;color:var(--text3);margin-top:2px;}

.est-goal-pct{font-size:18px;font-weight:800;}

.est-goal-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--text3);}

/* Pomodoro */

.est-pom-page{max-width:500px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:20px;}

.est-pom-modes{display:flex;gap:4px;background:var(--surface2);border-radius:10px;padding:4px;}

.est-pom-mode-btn{padding:6px 16px;border:none;background:none;color:var(--text3);border-radius:7px;cursor:pointer;font-size:12px;font-weight:600;transition:all .15s;}

.est-pom-mode-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.3);}

.est-pom-ring-wrap{position:relative;width:200px;height:200px;}

.est-pom-ring{width:200px;height:200px;}

.est-pom-time-wrap{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}

.est-pom-time{font-size:42px;font-weight:800;letter-spacing:2px;color:var(--text);}

.est-pom-session-lbl{font-size:11px;color:var(--text3);margin-top:4px;}

.est-pom-subject{width:100%;max-width:360px;text-align:center;}

.est-pom-controls{display:flex;align-items:center;gap:16px;}

.est-pom-cfg{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;font-size:12px;color:var(--text3);}

.est-pom-inp{width:52px;padding:4px 6px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;text-align:center;}

.est-pom-history{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;}

.est-pom-hist-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border2);font-size:12px;}

.est-pom-hist-row:last-child{border-bottom:none;}

.est-pom-hist-subj{flex:1;color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.est-pom-hist-dur{color:var(--accent2);font-weight:700;white-space:nowrap;}

.est-pom-hist-date{color:var(--text3);font-size:10px;white-space:nowrap;}

/* Estatisticas */

.est-stats{max-width:700px;margin:0 auto;}

.est-inline-prog{display:flex;flex-direction:column;gap:8px;}

.est-alert{padding:10px 12px;border:1px solid var(--border);border-left:3px solid var(--amber);border-radius:8px;background:var(--surface2);font-size:12px;color:var(--text2);margin-bottom:8px;}

.est-planner{max-width:960px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}

.est-kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}

.est-kan-col{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px;min-height:180px;}

.est-kan-hd{font-size:12px;font-weight:700;color:var(--text2);margin-bottom:8px;}

.est-kan-card{padding:8px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font-size:12px;color:var(--text);margin-bottom:8px;cursor:pointer;}

.est-subjects{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}

.est-notes{max-width:960px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}

.est-notes-grid{display:grid;grid-template-columns:320px 1fr;gap:12px;}

.est-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;}

.est-bar-label{width:120px;font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;}

.est-bar-track{flex:1;height:8px;background:var(--surface3);border-radius:99px;overflow:hidden;}

.est-bar-fill{height:100%;border-radius:99px;transition:width .5s;}

.est-bar-val{width:36px;font-size:11px;color:var(--text3);text-align:right;flex-shrink:0;}

.est-week-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:10px;}

.est-wchart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;}

.est-wchart-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;}

.est-wchart-bar{width:100%;background:var(--accent);border-radius:4px 4px 0 0;min-height:3px;transition:height .4s;}

.est-wchart-lbl{font-size:9px;color:var(--text3);font-weight:600;}

/* Responsive */

@media(max-width:640px){
  .est-stat-grid{grid-template-columns:repeat(2,1fr);}
  .est-dash-cols{grid-template-columns:1fr;}
  .est-kanban{grid-template-columns:1fr;}
  .est-notes-grid{grid-template-columns:1fr;}
  .est-tab-btn span{display:none;}
  .est-tab-btn{padding:8px 12px;}
}

/* ── MENTION CHIPS (@) ── */

.kb-mention{display:inline-flex;align-items:center;gap:3px;padding:1px 7px;border-radius:4px;font-size:.9em;font-weight:500;cursor:pointer;transition:filter .15s;white-space:nowrap;}

.kb-mention:hover{filter:brightness(1.2);}

.kb-mention-pilula{background:rgba(34,201,126,0.15);color:var(--green);border:1px solid rgba(34,201,126,0.3);}

.kb-mention-caderno{background:var(--accent-soft);color:var(--accent2);border:1px solid rgba(124,106,255,0.3);}

/* ── PÍLULAS ── */

.pilula-list{display:flex;flex-direction:column;gap:10px;margin-top:4px;}

.pilula-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;cursor:pointer;transition:all .15s;}

.pilula-card:hover{border-color:var(--border2);background:var(--surface2);}

.pilula-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}

.pilula-tipo-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:99px;letter-spacing:.03em;}

.pilula-titulo{font-size:15px;font-weight:600;color:var(--text);margin-bottom:5px;line-height:1.3;}

.pilula-descricao{font-size:13px;color:var(--text2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

.pilula-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px;}

.pilula-data{font-size:11px;color:var(--text3);margin-top:8px;}

.pilula-exemplo-code{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;font-family:'DM Mono',monospace;font-size:13px;color:var(--blue);overflow-x:auto;white-space:pre-wrap;word-break:break-word;margin:0;}

.pilula-exemplo-text{font-size:14px;line-height:1.7;color:var(--text);white-space:pre-wrap;}

/* ── FLUXOGRAMA ── */

.fluxo-editor-container{display:flex;flex-direction:column;height:calc(100vh - 170px);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}

.fluxo-toolbar{display:flex;align-items:center;gap:5px;padding:7px 10px;background:var(--surface2);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;}

.fluxo-tb-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-right:2px;flex-shrink:0;}

.fluxo-tb-sep{width:1px;background:var(--border);align-self:stretch;margin:0 4px;}

.fluxo-hint{font-size:11px;color:var(--text3);padding:5px 12px;background:var(--surface2);border-bottom:1px solid var(--border);flex-shrink:0;}

.fluxo-canvas-wrap{flex:1;overflow:auto;background:var(--surface);position:relative;cursor:default;}

.fluxo-svg{display:block;width:2400px;height:1400px;}

.fluxo-node{cursor:move;}

.fluxo-port{opacity:0;transition:opacity .12s;}

.fluxo-node:hover .fluxo-port{opacity:1;}

.fluxo-svg.fluxo-connecting .fluxo-port{opacity:1;}

.fluxo-edge-g{cursor:pointer;}

.fluxo-label-input{border:none;outline:2px solid var(--accent);background:var(--surface);color:var(--text);text-align:center;font-size:12px;font-family:inherit;border-radius:4px;padding:0 4px;z-index:20;box-sizing:border-box;}

/* ── CONTEXTO ── */

.ctx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-top:4px;}

.ctx-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:0;}

.ctx-card:hover{border-color:var(--border2);background:var(--surface2);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.08);}

.ctx-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}

.ctx-card-nome{font-size:15px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:6px;}

.ctx-card-preview{font-size:13px;color:var(--text2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}

.ctx-descricao-box{background:var(--accent-soft);border-left:3px solid var(--accent2);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:14px 16px;font-size:15px;line-height:1.7;color:var(--text);white-space:pre-wrap;}

.ctx-regras-box{background:rgba(255,94,94,0.08);border-left:3px solid #ff5e5e;border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:14px 16px;font-size:14px;line-height:1.75;color:var(--text);white-space:pre-wrap;}

.ctx-ia-box{background:linear-gradient(135deg,rgba(124,106,255,.08),rgba(165,148,255,.06));border:1px solid rgba(124,106,255,.2);border-radius:var(--radius-sm);padding:14px 16px;font-size:14px;line-height:1.75;color:var(--text);white-space:pre-wrap;}

.ctx-exemplos{display:flex;flex-direction:column;gap:10px;}

.ctx-exemplo-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);}

.ctx-exemplo-num{min-width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}

.ctx-exemplo-txt{font-size:14px;line-height:1.65;color:var(--text);white-space:pre-wrap;}

/* ========================================================
   CONTEXTO INLINE MODE (tab dentro do caderno)
   ======================================================== */

.ctx-inline-mode{padding:4px 0 48px;max-width:780px;margin:0 auto;}

.ctx-view-toggle{display:flex;gap:3px;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:3px;width:fit-content;margin-bottom:24px;}

.ctx-view-btn{padding:6px 16px;border:none;border-radius:6px;font-size:12px;font-weight:600;color:var(--text3);cursor:pointer;background:none;font-family:inherit;transition:all .15s;}

.ctx-view-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.15);}

.ctx-view-btn:not(.active):hover{color:var(--text2);}

.ctx-edit-content{display:flex;flex-direction:column;gap:20px;}

.ctx-view-content{display:flex;flex-direction:column;gap:4px;}

.ctx-inline-section{display:flex;flex-direction:column;gap:8px;}

.ctx-inline-label{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;}

.ctx-inline-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px;}

.ctx-inline-hint{font-size:10px;font-weight:400;color:var(--text3);text-transform:none;letter-spacing:0;margin-left:4px;}

.ctx-tipo-grid{display:flex;gap:6px;flex-wrap:wrap;}

.ctx-tipo-btn{padding:5px 14px;border:1px solid var(--border2);border-radius:99px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;background:var(--surface2);font-family:inherit;transition:all .15s;}

.ctx-tipo-btn:hover{background:var(--surface3);}

.ctx-tipo-btn.active{box-shadow:0 2px 8px rgba(0,0,0,.12);}

.ctx-inline-textarea{width:100%;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text);font-family:inherit;font-size:14px;line-height:1.7;padding:12px 14px;resize:vertical;min-height:76px;box-sizing:border-box;transition:border-color .15s,background .15s;}

.ctx-inline-textarea:focus{outline:none;border-color:var(--accent2);background:var(--surface);}

.ctx-inline-simples{border-left:3px solid var(--accent2);background:var(--accent-soft);}

.ctx-inline-regras{border-left:3px solid #ff5e5e;background:rgba(255,94,94,.06);}

.ctx-inline-regras:focus{border-color:#ff5e5e;border-right-color:var(--border2);border-top-color:var(--border2);border-bottom-color:var(--border2);}

.ctx-inline-ia{border-left:3px solid rgba(124,106,255,.7);background:linear-gradient(135deg,rgba(124,106,255,.07),rgba(165,148,255,.04));}

.ctx-inline-ia:focus{border-color:var(--accent2);border-right-color:var(--border2);border-top-color:var(--border2);border-bottom-color:var(--border2);}

.ctx-inline-ex-row,.ctx-inline-rel-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;}

.ctx-inline-inp{flex:1;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text);font-family:inherit;font-size:13px;padding:8px 12px;transition:border-color .15s,background .15s;}

.ctx-inline-inp:focus{outline:none;border-color:var(--accent2);background:var(--surface);}

.ctx-del-btn{border:none;background:none;color:var(--text3);cursor:pointer;padding:5px 8px;border-radius:6px;font-size:11px;transition:all .15s;flex-shrink:0;}

.ctx-del-btn:hover{background:rgba(255,94,94,.12);color:#ff5e5e;}

.ctx-inline-empty{font-size:13px;color:var(--text3);padding:10px 0;}

/* ========================================================
   MAPA DE CONHECIMENTO — V2
   ======================================================== */

.km-page{display:flex;flex-direction:column;gap:10px;overflow-x:hidden;}

.km-obsidian{height:calc(100vh - 46px);}

.km-stage{position:relative;flex:1;min-height:0;overflow-x:hidden;}

.km-floating-top{
  position:absolute;left:12px;right:12px;top:10px;z-index:30;
  display:flex;align-items:flex-start;justify-content:space-between;gap:10px;
  pointer-events:none;
}

.km-floating-top > *{pointer-events:auto;}

.km-brand{
  background:rgba(14,16,20,.72);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  padding:8px 12px;
  backdrop-filter:blur(8px);
}

.km-brand-title{font-size:12px;font-weight:700;color:#f2f4f7;letter-spacing:.04em;text-transform:uppercase;}

.km-brand-sub{font-size:11px;color:#a9b2c0;margin-top:2px;}

.km-page,.km-page *{font-family:var(--font-sans);}

.km-top-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;}

.km-toolbar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;}

/* Search */

.km-search-wrap{position:relative;display:flex;align-items:center;}

.km-search-icon{position:absolute;left:9px;width:13px;height:13px;color:var(--text3);pointer-events:none;}

.km-search-input{height:32px;padding:0 10px 0 30px;border:1px solid var(--border2);border-radius:999px;background:var(--surface2);color:var(--text);font-size:12px;font-family:'DM Sans',sans-serif;outline:none;width:160px;transition:border-color .15s,width .2s;}

.km-search-input:focus{border-color:rgba(72,227,211,.5);width:200px;}

.km-search-input::placeholder{color:var(--text3);}

/* Type filters */

.km-type-filters{display:flex;gap:4px;}

.km-filter-btn{height:30px;padding:0 9px;border:1px solid var(--border2);border-radius:999px;background:transparent;color:var(--text3);font-size:11px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;}

.km-filter-btn:hover{border-color:var(--border2);color:var(--text);background:var(--surface3);}

.km-filter-btn.active{background:var(--surface3);border-color:rgba(124,106,255,.5);color:var(--text);}

.km-filter-btn.type-objetivo.active{border-color:rgba(255,198,84,.6);color:#ffc654;}

.km-filter-btn.type-assunto.active{border-color:rgba(72,227,211,.6);color:#48e3d3;}

.km-filter-btn.type-curso.active{border-color:rgba(140,165,255,.6);color:#8ca5ff;}

.km-filter-btn.type-pratica.active{border-color:rgba(255,136,102,.6);color:#ff8866;}

.km-filter-btn.type-projeto.active{border-color:rgba(255,98,175,.6);color:#ff62af;}

/* Connect active */

.km-connect-active{background:rgba(72,227,211,.12)!important;border-color:rgba(72,227,211,.5)!important;color:#48e3d3!important;}

/* Layout */

.km-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:10px;align-items:start;}

/* Canvas */

.km-canvas-wrap{
  position:absolute;inset:0;min-height:76vh;border-radius:0;
  border:none;overflow:hidden;overflow-x:hidden;
  background-color:var(--bg);
  background-image:
    radial-gradient(ellipse 900px 500px at 5% 5%,  rgba(72,227,211,.03), transparent 55%),
    radial-gradient(ellipse 900px 500px at 95% 95%, rgba(124,106,255,.04), transparent 55%),
    radial-gradient(circle, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:auto, auto, 22px 22px;
  cursor:grab;
}

#knowledge-map-root,
#tr-map-root{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

.km-canvas-wrap:active{cursor:grabbing;}

.km-canvas-wrap.connect-mode{cursor:crosshair;}

/* World + layers */

.km-world{position:absolute;left:0;top:0;transform-origin:0 0;will-change:transform;}

.km-edges{position:absolute;left:0;top:0;width:3600px;height:2400px;pointer-events:none;overflow:visible;z-index:1;}

.km-edge-g .km-edge-hit{fill:none;stroke:transparent;stroke-width:14;pointer-events:stroke;cursor:pointer;}

.km-edge{fill:none;stroke:rgba(182,198,230,.38);stroke-width:1.9;stroke-linecap:round;pointer-events:none;transition:stroke .14s,opacity .14s,stroke-width .14s;}

.km-edge.hi{stroke:#48e3d3;stroke-width:2.4;filter:drop-shadow(0 0 4px rgba(72,227,211,.35));}

.km-edge.dim{opacity:.18;}

.km-edge:hover{stroke:#48e3d3;}

.km-nodes{position:absolute;left:0;top:0;width:3600px;height:2400px;z-index:2;}

/* Nodes */

.km-node{
  position:absolute;width:16px;height:16px;
  user-select:none;cursor:pointer;
  transition:opacity .15s;
}

.km-node:hover{
  opacity:1;
}

.km-node.sel{
  opacity:1;
}

.km-node.conn{opacity:1;border-color:var(--nc);}

.km-node.dim{opacity:.22;}

.km-node.hover-main{opacity:1;}

.km-node.status-em_andamento .km-dot{box-shadow:0 0 0 2px rgba(255,198,84,.35),0 0 12px rgba(255,198,84,.45);}

.km-node.status-concluido .km-dot{border-color:rgba(62,218,123,.9)!important;}

/* Node inner structure */

.km-dot{
  position:absolute;left:0;top:0;
  width:16px;height:16px;border-radius:50%;
  background:color-mix(in srgb, var(--nc) 40%, #d7deed);
  border:1.5px solid color-mix(in srgb, var(--nc) 75%, #ffffff);
  box-shadow:0 0 0 1px rgba(0,0,0,.35),0 0 10px var(--ng,rgba(72,227,211,.2));
}

.km-node.sel .km-dot{
  box-shadow:0 0 0 2px var(--nc),0 0 16px var(--ng,rgba(72,227,211,.3));
}

.km-node-label{
  position:absolute;
  left:22px;
  top:-2px;
  font-size:13px;
  color:#e8ecf6;
  font-weight:400;
  line-height:1.15;
  white-space:nowrap;
  text-shadow:0 1px 0 rgba(0,0,0,.35);
  pointer-events:none;
  letter-spacing:.01em;
  transform:translateZ(0);
}

/* Mini-map */

.km-minimap{
  position:absolute;right:12px;bottom:44px;
  background:rgba(10,14,26,.82);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;overflow:hidden;
  backdrop-filter:blur(6px);
  cursor:pointer;transition:opacity .2s;
  z-index:10;
}

.km-minimap:hover{opacity:.95;}

/* Zoom bar */

.km-zoom-bar{
  position:absolute;right:12px;bottom:10px;
  display:flex;align-items:center;gap:0;
  background:rgba(10,14,26,.82);
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;overflow:hidden;
  backdrop-filter:blur(6px);z-index:10;
}

.km-zoom-bar button{width:28px;height:28px;background:none;border:none;color:var(--text2);cursor:pointer;font-size:16px;line-height:1;transition:color .15s;}

.km-zoom-bar button:hover{color:var(--text);}

.km-zoom-bar span{font-size:11px;color:var(--text3);min-width:36px;text-align:center;padding:0 2px;}

/* Hint */

.km-hint{position:absolute;left:10px;bottom:10px;font-size:11px;color:#b5c3dd;background:rgba(10,14,26,.8);border:1px solid rgba(255,255,255,.08);padding:6px 11px;border-radius:999px;backdrop-filter:blur(4px);pointer-events:none;z-index:10;}

/* Context menu */

.km-ctx{
  position:fixed;z-index:9999;
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:5px;
  min-width:190px;
  box-shadow:0 16px 48px rgba(0,0,0,.5);
  animation:km-ctx-in .12s ease;
}

@keyframes km-ctx-in{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}

.km-ctx-head{font-size:11px;font-weight:700;color:var(--text3);padding:5px 8px 6px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.km-ctx button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text2);padding:7px 10px;border-radius:8px;cursor:pointer;font-size:13px;font-family:'DM Sans',sans-serif;transition:background .12s,color .12s;}

.km-ctx button:hover{background:var(--surface3);color:var(--text);}

.km-ctx button.danger:hover{background:rgba(255,94,94,.1);color:#ff5e5e;}

.km-ctx-sep{height:1px;background:var(--border);margin:4px 0;}

/* Side panel */

.km-side{display:flex;flex-direction:column;gap:9px;max-height:80vh;overflow:auto;padding-right:2px;}

.km-side-float{
  position:absolute;
  top:62px;
  right:10px;
  width:320px;
  max-height:calc(100% - 74px);
  z-index:25;
  padding-right:0;
  transition:transform .24s cubic-bezier(.22,.61,.36,1), opacity .2s ease, visibility .2s ease;
  visibility:visible;
}

.km-side-float.closed{
  transform:translateX(calc(100% + 12px));
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}

.km-side-float.open{
  transform:translateX(0);
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.km-side-toggle{
  position:absolute;
  top:70px;
  right:10px;
  z-index:26;
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface) 90%, transparent);
  color:var(--text2);
  cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.22);
  backdrop-filter:blur(6px);
  transition:all .18s ease;
}

.km-side-toggle:hover{color:var(--text);background:var(--surface2);border-color:var(--border2);}

.km-side-toggle.open{right:334px;}

.km-panel{background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:12px;}

.km-side-float .km-panel{
  background:color-mix(in srgb, var(--surface) 88%, transparent);
  border:1px solid var(--border);
  backdrop-filter:blur(8px);
}

.km-panel-title{font-size:11px;font-weight:700;color:var(--text);margin-bottom:9px;text-transform:uppercase;letter-spacing:.05em;}

.km-empty{font-size:12px;color:var(--text3);line-height:1.6;}

/* Edit panel */

.km-edit-panel{}

.km-edit-head{display:flex;align-items:center;gap:9px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border);position:relative;}

.km-edit-head::before{content:'';position:absolute;left:0;top:2px;bottom:2px;width:2px;background:color-mix(in srgb, var(--text3) 70%, transparent);border-radius:2px;}

.km-edit-icon{font-size:20px;flex-shrink:0;padding-left:8px;}

.km-close-btn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:18px;line-height:1;padding:2px 5px;border-radius:6px;transition:all .12s;flex-shrink:0;}

.km-close-btn:hover{background:var(--surface3);color:var(--text);}

/* Form controls inside panel */

.km-label{display:block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text3);margin:9px 0 4px;}

.km-ctrl{
  display:block;width:100%;box-sizing:border-box;
  appearance:none;-webkit-appearance:none;
  border:1px solid var(--border2);border-radius:9px;
  background:var(--surface2);color:var(--text);
  padding:8px 10px;font-family:'DM Sans',sans-serif;font-size:12px;
  line-height:1.4;outline:none;
  transition:border-color .15s,box-shadow .15s;
}

.km-ctrl:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 20%, transparent);}

.km-ctrl::placeholder{color:var(--text3);}

textarea.km-ctrl{min-height:80px;resize:vertical;}

select.km-ctrl{
  padding-right:28px;cursor:pointer;
  background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='%238b8b8b' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='m5 7 5 6 5-6'/%3E%3C/svg%3E\");
  background-repeat:no-repeat;background-position:right 8px center;background-size:11px 11px;
}

select.km-ctrl option{background:var(--surface2);color:var(--text);}

input[type="datetime-local"].km-ctrl::-webkit-calendar-picker-indicator{filter:invert(60%);cursor:pointer;}

/* Connections */

.km-conn-list{display:flex;flex-direction:column;gap:4px;}

.km-conn-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:8px;background:color-mix(in srgb, var(--surface2) 88%, transparent);border:1px solid var(--border);cursor:pointer;font-size:12px;color:var(--text2);transition:background .12s;}

.km-conn-item:hover{background:var(--surface3);color:var(--text);}

.km-conn-dir{font-size:11px;font-weight:700;flex-shrink:0;}

.km-conn-dir.in{color:rgba(140,165,255,.8);}

.km-conn-dir.out{color:rgba(72,227,211,.8);}

/* Actions */

.km-actions{display:flex;gap:5px;flex-wrap:wrap;margin-top:10px;}

.km-linked-task{margin-top:7px;font-size:11px;color:var(--text3);background:color-mix(in srgb, var(--surface2) 88%, transparent);border:1px solid var(--border);border-radius:8px;padding:6px 9px;}

/* Plan box */

.km-plan-box{margin-top:10px;padding:10px 11px;border:1px solid var(--border2);border-radius:10px;background:color-mix(in srgb, var(--surface2) 90%, transparent);}

.km-plan-title{font-size:10px;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.05em;}

.km-plan-date{font-size:10px;color:var(--text3);margin:3px 0 7px;}

.km-plan-steps{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:5px;list-style:decimal;}

.km-plan-steps li{font-size:11px;color:var(--text2);line-height:1.45;}

/* Suggestion */

.km-next .km-next-text{font-size:12px;color:var(--text2);line-height:1.55;margin-bottom:8px;}

/* Stats */

.km-stats{}

.km-prog-wrap{height:6px;border-radius:999px;background:var(--surface3);overflow:hidden;margin:8px 0 4px;}

.km-prog-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent2),var(--text2));transition:width .4s ease;}

.km-prog-label{font-size:11px;color:var(--text3);margin-bottom:8px;}

.km-type-row{display:flex;gap:6px;}

.km-type-chip{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:999px;background:color-mix(in srgb, var(--surface2) 88%, transparent);border:1px solid var(--border);font-size:12px;}

/* History */

.km-history-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px;}

.km-timeline{display:flex;flex-direction:column;gap:0;margin-top:8px;}

.km-tl-item{display:flex;gap:10px;padding:6px 0;}

.km-tl-item+.km-tl-item{border-top:1px solid var(--border);}

.km-tl-dot{width:8px;height:8px;border-radius:50%;background:rgba(124,106,255,.5);flex-shrink:0;margin-top:3px;}

.km-tl-body{flex:1;min-width:0;}

.km-tl-action{font-size:12px;color:var(--text);font-weight:600;}

.km-tl-detail{font-size:11px;color:var(--text2);line-height:1.4;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

.km-tl-time{font-size:10px;color:var(--text3);margin-top:2px;}

@media(max-width:1100px){
  .km-layout{grid-template-columns:1fr;}
  .km-canvas-wrap{position:relative;inset:auto;min-height:60vh;}
  .km-side{max-height:none;overflow:visible;}
  .km-side-float{position:static;width:100%;max-height:none;margin-top:10px;}
  .km-side-float.closed{display:none;}
  .km-side-float.open{display:flex;}
  .km-side-toggle{
    position:static;
    width:34px;
    height:34px;
    padding:0;
    margin:0 10px 8px auto;
    right:auto;
    border-radius:10px;
    box-shadow:none;
  }
  .km-side-toggle.open{right:auto;}
  .km-floating-top{
    position:static;
    padding:10px 10px 0;
    margin-bottom:8px;
    flex-direction:column;
  }
  .km-stage{display:flex;flex-direction:column;}
  .km-top-bar{flex-direction:column;}
  .km-toolbar{width:100%;}
}

/* KB MODULE TABS */

.kb-module-tabs{
  display:flex;
  gap:8px;
  align-items:center;
  margin-bottom:14px;
  padding:4px;
  border:1px solid var(--border2);
  border-radius:12px;
  background:var(--surface);
}

.kb-module-tab{
  border:none;
  background:transparent;
  color:var(--text2);
  padding:8px 12px;
  border-radius:8px;
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  font-weight:600;
  letter-spacing:.02em;
  cursor:pointer;
  transition:all .15s;
}

.kb-module-tab:hover{
  background:var(--surface2);
  color:var(--text);
}

.kb-module-tab.active{
  background:var(--accent-soft);
  color:var(--accent2);
  border:1px solid rgba(124,106,255,.35);
}

/* KB MODERN SWITCHER */

.kb-switch-wrap{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:0;
  margin-bottom:10px;
}

.kb-switch-title{display:none;}

.kb-switcher{
  display:inline-flex;
  align-items:center;
  gap:3px;
  padding:3px;
  border:1px solid var(--border2);
  border-radius:10px;
  background:var(--surface2);
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}

.kb-switch-btn{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border:none;
  background:none;
  color:var(--text3);
  border-radius:8px;
  padding:8px 22px;
  font-size:13px;
  font-weight:600;
  font-family:inherit;
  cursor:pointer;
  transition:all .18s;
  white-space:nowrap;
}

.kb-switch-btn:hover{color:var(--text2);background:var(--surface3);}

.kb-switch-btn.active{
  background:var(--surface);
  color:var(--text);
  box-shadow:0 1px 6px rgba(0,0,0,.18);
}

.kb-switch-btn.active .kb-switch-ico svg{stroke:var(--accent2);}

.kb-switch-ico{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.kb-switch-ico svg{width:15px;height:15px;stroke:currentColor;}

.kb-switch-txt{display:flex;flex-direction:column;gap:2px;min-width:0;}

.kb-switch-txt b{font-size:13px;font-weight:600;line-height:1.1;color:inherit;white-space:nowrap;}

.kb-switch-txt small{display:none;}

@media(max-width:780px){
  .kb-switcher{overflow-x:auto;-webkit-overflow-scrolling:touch;}
}

/* ══════════════════════════════════════
   TRABALHO PANEL
══════════════════════════════════════ */

.trab-tab-bar{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;
  background:rgba(255,255,255,0.03);
  box-shadow:0 2px 10px rgba(0,0,0,.2);
}

#trab-tab-bar{
  position:sticky;
  top:0;
  z-index:18;
  display:flex;
  justify-content:center;
  padding:10px 14px 8px;
  background:transparent;
  border-bottom:none;
  backdrop-filter:none;
}

.trab-tab{
  display:flex;
  align-items:center;
  gap:7px;
  padding:8px 14px;
  border-radius:10px;
  font-size:13px;
  font-weight:600;
  color:#c8cbcf;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  cursor:pointer;
  transition:all .16s;
  white-space:nowrap;
}

.trab-tab svg{width:15px;height:15px;stroke:currentColor;flex-shrink:0;}

.trab-tab:hover{color:#fff;background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.15);}

.trab-tab.active{
  color:#fff;
  background:#1f2127;
  border-color:#8c7cff;
  box-shadow:0 0 0 1px rgba(140,124,255,0.18) inset;
}

.trab-tab.active svg{stroke:var(--accent2);}

/* Panel content */

.trab-panel{padding:18px 20px 84px;max-width:980px;margin:0 auto;}

.trab-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin:0 0 10px;}

.trab-section{margin-bottom:28px;}

/* Cards */

.trab-card{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:14px 16px;margin-bottom:8px;cursor:pointer;
  transition:border-color .16s,box-shadow .16s,transform .16s;
  display:flex;align-items:flex-start;gap:12px;
}

.trab-card:hover{
  border-color:var(--accent2);
  box-shadow:0 8px 20px rgba(0,0,0,.15);
  transform:translateY(-1px);
}

.trab-card-body{flex:1;min-width:0;}

.trab-card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.trab-card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;}

/* Badges */

.trab-badge{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;
}

.trab-badge-pend{background:#2a2a35;color:#9997a8;}

.trab-badge-andando{background:#1a2a40;color:#60a5fa;}

.trab-badge-concluida{background:#1a3028;color:var(--green);}

.trab-badge-cancelada{background:#2d1f1f;color:var(--red);}

.trab-badge-alta{background:#3d1f1f;color:var(--red);}

.trab-badge-media{background:#2d2510;color:var(--amber);}

.trab-badge-baixa{background:#1a2510;color:var(--green);}

.trab-badge-area{background:var(--surface2);color:var(--text3);}

.trab-badge-vencida{background:#3d1f1f;color:var(--red);}

/* Card priority dot */

.trab-prio-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px;}

.trab-prio-dot.alta{background:var(--red);}

.trab-prio-dot.media{background:var(--amber);}

.trab-prio-dot.baixa{background:var(--green);}

.trab-prio-dot.none{background:var(--border2);}

/* Hoje columns */

.trab-hoje-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}

@media(max-width:680px){.trab-hoje-grid{grid-template-columns:1fr;}}

.trab-hoje-col{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;}

.trab-hoje-col-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:10px;display:flex;align-items:center;gap:6px;}

.trab-hoje-col-title svg{width:13px;height:13px;}

.trab-hoje-col-title.is-warn{color:var(--red);}

.trab-hoje-empty{font-size:12px;color:var(--text3);text-align:center;padding:10px 0;}

/* Detail view */

.trab-detail-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;}

.trab-back-btn{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text3);cursor:pointer;padding:4px 8px;border-radius:8px;background:none;border:none;}

.trab-back-btn:hover{color:var(--text);background:var(--surface2);}

.trab-back-btn svg{width:15px;height:15px;}

.trab-detail-title{font-size:18px;font-weight:700;color:var(--text);flex:1;}

.trab-detail-title-input{font-size:18px;font-weight:700;color:var(--text);flex:1;background:none;border:none;border-bottom:2px solid var(--accent2);outline:none;padding:2px 4px;}

.trab-detail-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;}

@media(max-width:600px){.trab-detail-fields{grid-template-columns:1fr;}}

.trab-field{display:flex;flex-direction:column;gap:4px;}

.trab-field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);}

.trab-field select,.trab-field input[type=text],.trab-field input[type=date]{
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:13px;padding:7px 10px;outline:none;
}

.trab-field select:focus,.trab-field input:focus{border-color:var(--accent2);}

.trab-field textarea{
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:13px;padding:8px 10px;outline:none;resize:vertical;min-height:80px;
}

.trab-field textarea:focus{border-color:var(--accent2);}

/* Timer */

.trab-timer-wrap{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:16px;margin-bottom:20px;display:flex;align-items:center;gap:14px;
}

.trab-timer-display{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text);letter-spacing:.04em;}

.trab-timer-label{font-size:11px;color:var(--text3);margin-top:2px;}

.trab-timer-total{font-size:12px;color:var(--text3);}

.trab-timer-btn{
  display:flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:8px;border:none;cursor:pointer;
  font-size:13px;font-weight:600;
}

.trab-timer-btn.start{background:var(--accent2);color:#fff;}

.trab-timer-btn.stop{background:var(--red);color:#fff;}

.trab-timer-btn svg{width:14px;height:14px;}

/* Observations */

.trab-obs-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;}

.trab-obs-item{
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  padding:10px 12px;display:flex;gap:10px;align-items:flex-start;
}

.trab-obs-body{flex:1;min-width:0;}

.trab-obs-text{font-size:13px;color:var(--text);line-height:1.5;white-space:pre-wrap;word-break:break-word;}

.trab-obs-date{font-size:11px;color:var(--text3);margin-top:4px;}

.trab-obs-del{background:none;border:none;cursor:pointer;color:var(--text3);padding:2px;border-radius:4px;flex-shrink:0;}

.trab-obs-del:hover{color:var(--red);}

.trab-obs-del svg{width:13px;height:13px;}

.trab-obs-input{
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  padding:10px 12px;display:flex;gap:8px;align-items:flex-end;
}

.trab-obs-input textarea{
  flex:1;background:none;border:none;outline:none;
  font-size:13px;color:var(--text);resize:none;min-height:36px;max-height:120px;
  font-family:inherit;
}

.trab-obs-send{
  background:var(--accent2);border:none;border-radius:6px;cursor:pointer;
  color:#fff;padding:6px 12px;font-size:12px;font-weight:600;flex-shrink:0;
}

/* Areas */

.trab-areas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;}

.trab-area-card{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:16px;cursor:pointer;transition:border-color .15s;
  display:flex;flex-direction:column;gap:8px;
}

.trab-area-card:hover{border-color:var(--accent2);}

.trab-area-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;}

.trab-area-name{font-size:14px;font-weight:700;color:var(--text);}

.trab-area-count{font-size:12px;color:var(--text3);}

.trab-area-add{
  background:none;border:2px dashed var(--border2);border-radius:14px;
  padding:16px;cursor:pointer;color:var(--text3);font-size:13px;font-weight:500;
  display:flex;align-items:center;justify-content:center;gap:6px;
  transition:border-color .15s,color .15s;
}

.trab-area-add:hover{border-color:var(--accent2);color:var(--accent2);}

.trab-area-add svg{width:16px;height:16px;}

/* Search/filter bar */

.trab-filter-bar{
  display:flex;
  gap:8px;
  margin-bottom:16px;
  flex-wrap:wrap;
  position:sticky;
  top:64px;
  z-index:12;
  padding:10px;
  border:1px solid var(--border);
  border-radius:12px;
  background:rgba(19,20,24,.92);
  backdrop-filter:blur(6px);
}

.trab-search{
  flex:1;min-width:160px;background:var(--surface);border:1px solid var(--border);
  border-radius:9px;padding:9px 12px;font-size:13px;color:var(--text);outline:none;
}

.trab-search:focus{border-color:var(--accent2);}

.trab-filter-select{
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  padding:8px 10px;font-size:13px;color:var(--text);outline:none;cursor:pointer;
}

.trab-filter-select:focus{border-color:var(--accent2);}

/* Add button */

.trab-add-btn{
  display:flex;align-items:center;gap:6px;
  background:var(--accent2);color:#fff;border:none;border-radius:8px;
  padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;
  transition:filter .15s,transform .15s;
}

.trab-add-btn svg{width:14px;height:14px;}

.trab-add-btn:hover{filter:brightness(1.06);transform:translateY(-1px);}

/* Empty state */

.trab-empty{text-align:center;padding:40px 20px;color:var(--text3);font-size:14px;}

.trab-empty svg{width:36px;height:36px;opacity:.3;margin-bottom:10px;}

/* Modal */

.trab-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;}

.trab-modal{background:var(--surface);border:1px solid var(--border2);border-radius:16px;width:100%;max-width:460px;padding:24px;box-shadow:0 8px 40px rgba(0,0,0,.4);}

.trab-modal-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:18px;}

.trab-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;}

.trab-modal-cancel{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;}

.trab-modal-save{background:var(--accent2);border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;}

/* Stat cards for Hoje */

.trab-stat-row{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;}

.trab-stat{
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0) 45%),var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 16px;
  flex:1;
  min-width:110px;
}

.trab-stat-num{font-size:24px;font-weight:800;color:var(--text);}

.trab-stat-label{font-size:11px;color:var(--text3);margin-top:2px;}

.trab-stat.warn .trab-stat-num{color:var(--red);}

.trab-stat.ok .trab-stat-num{color:var(--green);}

.trab-stat.info .trab-stat-num{color:#60a5fa;}

/* KB framework radial launcher */

.kb-radial-launch-wrap{
  display:flex;
  justify-content:center;
  margin:-4px 0 14px;
}

.kb-radial-launch{
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(124,106,255,.45);
  background:linear-gradient(135deg,rgba(124,106,255,.2),rgba(46,213,255,.14));
  color:var(--text);
  border-radius:999px;
  padding:10px 16px;
  cursor:pointer;
  font-weight:700;
  box-shadow:0 8px 26px rgba(0,0,0,.28), inset 0 0 0 1px rgba(255,255,255,.05);
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.kb-radial-launch span{font-size:16px;line-height:1;color:#cfc7ff;}

.kb-radial-launch b{font-size:12px;letter-spacing:.02em;}

.kb-radial-launch:hover{transform:translateY(-1px) scale(1.02);filter:brightness(1.05);}

.kb-radial-overlay{
  position:fixed;
  inset:0;
  z-index:1300;
  background:radial-gradient(circle at center, rgba(62,55,120,.24), rgba(2,4,10,.74));
  backdrop-filter:blur(2px);
  opacity:0;
  transition:opacity .2s ease;
}

.kb-radial-overlay.open{opacity:1;}

.kb-radial-wrap{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
}

.kb-radial-ring{
  position:relative;
  width:min(62vw,420px);
  height:min(62vw,420px);
  min-width:270px;
  min-height:270px;
}

.kb-radial-core{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:112px;
  height:112px;
  border-radius:50%;
  border:1px solid rgba(124,106,255,.45);
  background:radial-gradient(circle at 30% 20%, rgba(165,148,255,.35), rgba(24,23,42,.96));
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  box-shadow:0 12px 30px rgba(0,0,0,.36), inset 0 0 0 1px rgba(255,255,255,.06);
  cursor:pointer;
}

.kb-radial-core b{font-size:15px;}

.kb-radial-core small{font-size:10px;color:#c9c2ff;}

.kb-radial-item{
  --r:min(26vw,150px);
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%) rotate(var(--a)) translate(0) rotate(calc(var(--a) * -1));
  opacity:0;
  border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(239,244,255,.92));
  color:#1c2f66;
  border-radius:999px;
  min-width:136px;
  padding:8px 12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  font-size:12px;
  font-weight:700;
  box-shadow:0 8px 20px rgba(0,0,0,.24);
  cursor:pointer;
  transition:transform .28s cubic-bezier(.2,.8,.2,1), opacity .2s ease, box-shadow .2s ease, filter .2s ease, border-color .2s ease;
  transition-delay:var(--delay,0ms);
}

.kb-radial-overlay.open .kb-radial-item{
  transform:translate(-50%,-50%) rotate(var(--a)) translate(var(--r)) rotate(calc(var(--a) * -1));
  opacity:1;
}

.kb-radial-item .ico{
  width:20px;
  height:20px;
  border-radius:50%;
  background:#fff;
  display:grid;
  place-items:center;
  box-shadow:inset 0 0 0 1px rgba(124,106,255,.22);
}

.kb-radial-item .ico svg{
  width:13px;
  height:13px;
  stroke:#5a4dd8;
}

.kb-radial-item:hover{
  border-color:rgba(124,106,255,.62);
  box-shadow:0 12px 26px rgba(0,0,0,.34), 0 0 18px rgba(124,106,255,.38), 0 0 34px rgba(124,106,255,.18);
  filter:brightness(1.08);
}

.kb-radial-item:hover .ico{
  box-shadow:inset 0 0 0 1px rgba(124,106,255,.4), 0 0 12px rgba(124,106,255,.45);
  background:linear-gradient(180deg,#ffffff,#f2efff);
}

.kb-radial-item:hover .ico svg{
  stroke:#4f3fff;
}

@media(max-width:900px){
  .trab-panel{max-width:100%;}
  .trab-filter-bar{top:58px;}
}

@media(max-width:640px){
  .kb-radial-ring{
    width:min(86vw,340px);
    height:min(86vw,340px);
    min-width:250px;
    min-height:250px;
  }
  .kb-radial-item{
    --r:min(34vw,120px);
    min-width:120px;
    font-size:11px;
    padding:7px 10px;
  }
  .kb-radial-core{
    width:96px;
    height:96px;
  }
  #trab-tab-bar{
    justify-content:flex-start;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .trab-tab-bar{min-width:max-content;}
  .trab-panel{padding:14px 12px 92px;}
  .trab-filter-bar{
    position:static;
    padding:0;
    border:none;
    border-radius:0;
    background:none;
    backdrop-filter:none;
  }
  .trab-search,.trab-filter-select,.trab-add-btn{width:100%;}
}

/* ══════════════════════════════════════
   DICIONÁRIO DB
══════════════════════════════════════ */

.dbd-head{margin-bottom:10px;}

.dbd-stats{display:flex;gap:8px;flex-wrap:wrap;}

.dbd-stats span{font-size:11px;color:var(--text2);padding:5px 9px;border:1px solid var(--border2);background:var(--surface2);border-radius:999px;}

.dbd-topbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px;}

.dbd-topbar .kb-search{flex:1;min-width:260px;}

.dbd-tabs{display:flex;gap:6px;flex-wrap:wrap;}

.dbd-tab{border:1px solid var(--border2);background:var(--surface2);color:var(--text2);padding:7px 10px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;}

.dbd-tab.active{background:var(--accent-soft);color:var(--accent2);border-color:var(--accent);}

.dbd-cats{margin-bottom:14px;}

.dbd-status-filter{min-width:140px;}

.dbd-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:12px;align-items:start;}

.dbd-list-panel,.dbd-detail-panel,.dbd-section,.dbd-diagram-layout{background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:12px;}

.dbd-list-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;}

.dbd-list{display:flex;flex-direction:column;gap:6px;max-height:68vh;overflow:auto;padding-right:2px;}

.dbd-list-item{border:1px solid var(--border);background:var(--surface2);color:var(--text);border-radius:10px;padding:10px;text-align:left;cursor:pointer;}

.dbd-list-item b{display:block;font-size:13px;}

.dbd-list-item small{font-size:11px;color:var(--text3);}

.dbd-list-item.active{border-color:var(--accent);box-shadow:0 0 0 1px rgba(124,106,255,.25);}

.dbd-detail-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;}

.dbd-detail-head h3{margin:0;font-size:16px;}

.dbd-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

.dbd-grid-2 label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--text2);}

.dbd-grid-2 textarea{min-height:72px;}

.dbd-detail-panel .form-input,
.dbd-detail-panel .form-control,
.dbd-modal-body .form-input,
.dbd-modal-body .form-control{
  width:100%;
  appearance:none;
  -webkit-appearance:none;
  border:1px solid var(--border2);
  border-radius:10px;
  background:var(--surface2);
  color:var(--text);
  padding:10px 12px;
  font-size:13px;
  font-family:'DM Sans',sans-serif;
  outline:none;
  box-sizing:border-box;
  transition:border-color .15s, box-shadow .15s, background .15s;
}

.dbd-detail-panel .form-control:focus,
.dbd-detail-panel .form-input:focus,
.dbd-modal-body .form-control:focus,
.dbd-modal-body .form-input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(124,106,255,.15);
  background:var(--surface);
}

.dbd-detail-panel textarea.form-control,
.dbd-modal-body textarea.form-control{
  min-height:86px;
  resize:vertical;
  line-height:1.55;
}

.dbd-detail-panel textarea.form-control[readonly]{
  min-height:64px;
  opacity:.95;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ──── DATABASE DICTIONARY - MODERN DESIGN ──── */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.dbd-modern-container {
  padding: 20px 28px;
  max-width: 1800px;
  margin: 0 auto;
}

/* ──── Slim sidebar items ──── */

.dbd-slim-item {
  width: 100%;
  text-align: left;
  background: none;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 8px 10px;
  cursor: pointer;
  transition: all 0.15s;
  color: var(--text);
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.dbd-slim-item:hover { background: var(--surface2); border-color: var(--border); }

.dbd-slim-item.active { background: var(--accent-soft); border-color: var(--accent); }

.dbd-slim-main { display: flex; align-items: center; gap: 6px; }

.dbd-slim-name { font-size: 13px; font-weight: 600; font-family: 'DM Mono', monospace; color: var(--text); }

.dbd-slim-star { font-size: 10px; color: var(--amber); }

.dbd-slim-sub { display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--text3); }

.dbd-slim-draft { font-size: 10px; padding: 1px 6px; background: rgba(96,165,250,0.15); color: #60a5fa; border-radius: 3px; margin-left: 2px; }

/* ──── Detail topbar ──── */

.dbd-detail-topbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.dbd-detail-name {
  font-family: 'Syne', sans-serif;
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 6px;
  color: var(--text);
}

.dbd-detail-inline-chips { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

.dbd-chip-cat { font-size: 11px; padding: 3px 8px; background: rgba(124,106,255,0.12); color: var(--accent2); border-radius: 4px; font-weight: 500; }

.dbd-chip-main { font-size: 11px; padding: 3px 8px; background: rgba(251,191,36,0.12); color: var(--amber); border-radius: 4px; font-weight: 500; }

.dbd-chip-status.pub { font-size: 11px; padding: 3px 8px; background: rgba(34,197,94,0.1); color: #4ade80; border-radius: 4px; }

.dbd-chip-status.draft { font-size: 11px; padding: 3px 8px; background: rgba(59,130,246,0.1); color: #60a5fa; border-radius: 4px; }

.dbd-detail-btns { display: flex; gap: 6px; flex-shrink: 0; flex-wrap: wrap; }

/* ──── Description & extras ──── */

.dbd-detail-desc-main {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.6;
  padding: 10px 14px;
  background: var(--surface3);
  border-radius: 8px;
  border-left: 2px solid var(--accent);
  margin: 0;
}

.dbd-extra-block {
  background: var(--surface3);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}

.dbd-extra-block summary {
  padding: 9px 14px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text2);
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.dbd-extra-block summary::-webkit-details-marker { display: none; }

.dbd-extra-block summary::before { content: '▸  '; color: var(--text3); font-size: 10px; }

.dbd-extra-block[open] summary::before { content: '▾  '; }

.dbd-extra-block-body {
  padding: 4px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 1px solid var(--border);
}

.dbd-extra-item { display: flex; flex-direction: column; gap: 4px; }

.dbd-extra-item label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text3); }

.dbd-extra-item p, .dbd-extra-item li { font-size: 12px; color: var(--text2); margin: 0; line-height: 1.5; }

.dbd-extra-item ul { margin: 0; padding-left: 16px; display: flex; flex-direction: column; gap: 3px; }

.dbd-extra-warn label { color: var(--red); }

.dbd-extra-warn li { color: #fca5a5; }

/* ──── Schema table ──── */

.dbd-schema-section { display: flex; flex-direction: column; gap: 10px; }

.dbd-schema-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.dbd-schema-header > span { font-size: 13px; font-weight: 600; color: var(--text2); }

.dbd-schema-count {
  font-size: 11px;
  font-weight: 500;
  padding: 1px 6px;
  background: var(--surface3);
  border-radius: 99px;
  color: var(--text3);
  margin-left: 4px;
}

.dbd-schema-table {
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}

.dbd-schema-thead,
.dbd-schema-row {
  display: grid;
  grid-template-columns: 14px 1fr 88px 1.4fr 76px;
  gap: 10px;
  align-items: center;
  padding: 0 12px;
}

.dbd-schema-thead {
  padding-top: 7px;
  padding-bottom: 7px;
  background: var(--surface3);
  border-bottom: 1px solid var(--border);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text3);
}

.dbd-schema-row {
  padding-top: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
  transition: background 0.12s;
}

.dbd-schema-row:last-child { border-bottom: none; }

.dbd-schema-row:hover { background: rgba(255,255,255,0.02); }

.dbd-schema-row.is-critical { border-left: 2px solid rgba(239,68,68,0.55); }

.dbd-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--border2);
  display: inline-block;
  flex-shrink: 0;
}

.dbd-dot.crit { background: rgba(239,68,68,0.85); box-shadow: 0 0 5px rgba(239,68,68,0.35); }

.dbd-sch-dot { display: flex; align-items: center; justify-content: center; }

.dbd-sch-name b { font-size: 13px; font-family: 'DM Mono', monospace; font-weight: 500; color: var(--text); }

.dbd-sch-type code { font-size: 11px; font-family: 'DM Mono', monospace; padding: 2px 7px; background: rgba(124,106,255,0.1); color: var(--accent2); border-radius: 4px; }

.dbd-sch-desc { font-size: 12px; color: var(--text2); line-height: 1.4; overflow: hidden; text-overflow: ellipsis; }

.dbd-rules-inline { color: var(--text3); font-size: 11px; font-family: 'DM Mono', monospace; }

.dbd-sch-empty { color: var(--text3); }

.dbd-sch-acts { display: flex; gap: 2px; justify-content: flex-end; }

/* Header compacto */

.dbd-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.dbd-page-title {
  font-family: 'Syne', sans-serif;
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 6px;
  color: var(--text);
}

.dbd-stat-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.dbd-stat-chips span {
  font-size: 11px;
  padding: 3px 9px;
  background: var(--surface3);
  border: 1px solid var(--border2);
  border-radius: 99px;
  color: var(--text2);
}

/* Toolbar */

.dbd-modern-toolbar {
  display: flex;
  gap: 16px;
  margin-bottom: 20px;
  align-items: center;
}

.dbd-search-wrapper {
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
}

.dbd-search-icon {
  position: absolute;
  left: 12px;
  width: 16px;
  height: 16px;
  color: var(--text3);
  pointer-events: none;
}

.dbd-search-input {
  width: 100%;
  padding: 12px 16px 12px 40px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  font-size: 14px;
  transition: border-color 0.2s, background 0.2s;
}

.dbd-search-input:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--surface);
}

.dbd-toolbar-controls {
  display: flex;
  gap: 8px;
}

.dbd-filter-select {
  padding: 10px 14px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-size: 13px;
  cursor: pointer;
  transition: border-color 0.2s;
}

.dbd-filter-select:focus {
  outline: none;
  border-color: var(--accent);
}

/* Tabs */

.dbd-modern-tabs {
  margin-bottom: 20px;
  overflow-x: auto;
  padding-bottom: 12px;
}

.dbd-tabs-scroll {
  display: flex;
  gap: 8px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0;
  flex-wrap: wrap;
}

.dbd-tab {
  padding: 10px 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text2);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  margin-bottom: -1px;
  white-space: nowrap;
}

.dbd-tab:hover {
  color: var(--text);
  background: rgba(255,255,255,0.03);
}

.dbd-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* Categories */

.dbd-modern-cats {
  display: flex;
  gap: 8px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}

.dbd-cat-btn {
  padding: 8px 16px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}

.dbd-cat-btn:hover {
  background: var(--surface3);
  border-color: var(--border2);
  color: var(--text);
}

.dbd-cat-btn.active {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent2);
}

/* Content */

.dbd-modern-content {
  animation: fadeIn 0.2s ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* ──── Tables Layout ──── */

.dbd-tables-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 24px;
}

@media (max-width: 1200px) {
  .dbd-tables-grid {
    grid-template-columns: 1fr;
  }
}

.dbd-tables-list {
  display: flex;
  flex-direction: column;
}

.dbd-list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.dbd-list-header h3 {
  font-size: 18px;
  font-weight: 600;
  margin: 0;
}

.dbd-list-actions {
  display: flex;
  gap: 8px;
}

.dbd-list-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow-y: auto;
  max-height: 600px;
  padding-right: 8px;
}

.dbd-table-card {
  padding: 12px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
}

.dbd-table-card:hover {
  background: var(--surface3);
  border-color: var(--border2);
}

.dbd-table-card.selected {
  background: var(--accent-soft);
  border-color: var(--accent);
}

.dbd-table-card-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 8px;
  margin-bottom: 8px;
}

.dbd-table-card-header h4 {
  font-size: 14px;
  font-weight: 600;
  margin: 0;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
}

.dbd-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.dbd-badge {
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 500;
  white-space: nowrap;
}

.dbd-badge-main {
  background: rgba(245, 166, 35, 0.2);
  color: var(--amber);
}

.dbd-badge-pub {
  background: rgba(34, 201, 126, 0.2);
  color: var(--green);
}

.dbd-badge-draft {
  background: rgba(79, 163, 255, 0.2);
  color: var(--blue);
}

.dbd-table-card-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.dbd-cat-label {
  font-size: 11px;
  padding: 4px 8px;
  background: rgba(124, 106, 255, 0.1);
  color: var(--accent2);
  border-radius: 4px;
  font-weight: 500;
}

.dbd-field-count {
  font-size: 11px;
  color: var(--text3);
}

.dbd-table-desc {
  font-size: 12px;
  color: var(--text2);
  margin: 6px 0;
  line-height: 1.4;
}

.dbd-field-tags {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.dbd-field-tag {
  font-size: 10px;
  padding: 3px 6px;
  background: rgba(255,255,255,0.05);
  color: var(--text3);
  border-radius: 3px;
}

.dbd-empty-state {
  padding: 40px 20px;
  text-align: center;
  color: var(--text3);
}

.dbd-empty-state h3 {
  font-size: 16px;
  margin-bottom: 8px;
  color: var(--text2);
}

.dbd-empty-state p {
  font-size: 13px;
}

/* ──── Detail Panel ──── */

.dbd-table-detail {
  padding: 24px;
  background: var(--surface2);
  border-radius: 12px;
  border: 1px solid var(--border);
  overflow-y: auto;
  max-height: 600px;
}

.dbd-detail-wrapper {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.dbd-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

.dbd-detail-header h2 {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 8px;
}

.dbd-detail-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.dbd-category {
  font-size: 11px;
  padding: 4px 8px;
  background: rgba(124, 106, 255, 0.1);
  color: var(--accent2);
  border-radius: 4px;
  font-weight: 500;
}

.dbd-tag-main,
.dbd-tag-status {
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 500;
}

.dbd-tag-main {
  background: rgba(245, 166, 35, 0.2);
  color: var(--amber);
}

.dbd-tag-status {
  background: rgba(34, 201, 126, 0.2);
  color: var(--green);
}

.dbd-tag-status.draft {
  background: rgba(79, 163, 255, 0.2);
  color: var(--blue);
}

.dbd-detail-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.dbd-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dbd-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.dbd-section-header h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 0;
}

.dbd-section h3 {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  margin: 0;
}

.dbd-section h4 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 4px;
}

.dbd-description-block {
  padding: 12px;
  background: rgba(124, 106, 255, 0.08);
  border-left: 3px solid var(--accent);
  border-radius: 6px;
}

.dbd-description-block label {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: block;
  margin-bottom: 6px;
}

.dbd-description-block p {
  font-size: 13px;
  color: var(--text);
  line-height: 1.6;
  margin: 0;
}

.dbd-fields-modern {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dbd-field-row {
  padding: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dbd-field-name-type {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.dbd-field-name-type b {
  font-size: 13px;
  color: var(--text);
}

.dbd-type {
  font-size: 11px;
  padding: 2px 6px;
  background: var(--surface2);
  color: var(--accent2);
  border-radius: 3px;
  font-family: 'DM Mono', monospace;
  font-weight: 500;
}

.dbd-critical {
  font-size: 10px;
  padding: 2px 6px;
  background: rgba(255, 94, 94, 0.2);
  color: var(--red);
  border-radius: 3px;
  font-weight: 500;
  white-space: nowrap;
}

.dbd-field-description {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.4;
}

.dbd-field-rules {
  font-size: 11px;
  padding: 6px 8px;
  background: rgba(245, 166, 35, 0.1);
  color: var(--amber);
  border-radius: 4px;
  font-family: 'DM Mono', monospace;
  overflow-x: auto;
}

.dbd-field-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.dbd-info-block {
  padding: 12px;
  background: rgba(79, 163, 255, 0.08);
  border-left: 3px solid var(--blue);
  border-radius: 6px;
}

.dbd-info-rules {
  background: rgba(245, 166, 35, 0.08);
  border-left-color: var(--amber);
}

.dbd-info-errors {
  background: rgba(255, 94, 94, 0.08);
  border-left-color: var(--red);
}

.dbd-info-block h4 {
  margin-bottom: 8px;
}

.dbd-info-block p {
  font-size: 12px;
  color: var(--text);
  margin: 0;
}

.dbd-info-block ul {
  margin: 0;
  padding-left: 20px;
}

.dbd-info-block li {
  font-size: 12px;
  color: var(--text);
  margin-bottom: 4px;
}

/* ──── Cards Grid ──── */

.dbd-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
}

.dbd-card-modern {
  padding: 16px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: all 0.2s;
}

.dbd-card-modern:hover {
  background: var(--surface3);
  border-color: var(--border2);
}

.dbd-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

.dbd-card-header h4 {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
}

.dbd-card-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-self: flex-start;
}

.dbd-rel-type,
.dbd-rule-badge {
  font-size: 10px;
  padding: 3px 8px;
  background: var(--accent-soft);
  color: var(--accent2);
  border-radius: 4px;
  font-weight: 500;
  white-space: nowrap;
}

.dbd-card-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-size: 13px;
}

.dbd-card-desc {
  margin: 0;
  color: var(--text2);
  line-height: 1.5;
}

.dbd-card-meta {
  font-size: 11px;
  color: var(--text3);
}

.dbd-rel-info {
  padding: 8px;
  background: rgba(255,255,255,0.03);
  border-radius: 6px;
}

.dbd-rel-info label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  color: var(--text3);
  margin-bottom: 4px;
  text-transform: uppercase;
}

.dbd-rel-info code {
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  color: var(--accent2);
}

.dbd-sql-block {
  background: rgba(255,255,255,0.03);
  border-radius: 6px;
  padding: 0;
}

.dbd-sql-block summary {
  padding: 8px 12px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 500;
  color: var(--text2);
  user-select: none;
}

.dbd-sql-block summary:hover {
  color: var(--text);
}

.dbd-sql-block pre {
  margin: 0;
  padding: 12px;
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-radius: 0 0 6px 6px;
  overflow-x: auto;
}

.dbd-sql-code {
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  color: var(--text2);
  margin: 0;
}

.dbd-card-section {
  font-size: 12px;
}

.dbd-card-section label {
  display: block;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.dbd-card-section p {
  margin: 0;
  color: var(--text2);
  line-height: 1.5;
}

.dbd-card-section ul {
  margin: 0;
  padding-left: 18px;
}

.dbd-card-section li {
  margin-bottom: 4px;
  color: var(--text2);
}

.dbd-section-errors {
  background: rgba(255, 94, 94, 0.08);
}

.dbd-analysis-section {
  font-size: 12px;
}

.dbd-analysis-section label {
  display: block;
  font-weight: 600;
  margin-bottom: 8px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--text);
}

.dbd-analysis-items {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.dbd-tag {
  font-size: 11px;
  padding: 4px 8px;
  background: var(--accent-soft);
  color: var(--accent2);
  border-radius: 4px;
  white-space: nowrap;
}

.dbd-card-actions {
  display: flex;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.05);
  flex-wrap: wrap;
}

/* ──── Rules ──── */

.dbd-rules-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dbd-rule-card {
  padding: 14px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-left: 4px solid var(--blue);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dbd-rule-critical {
  border-left-color: var(--red);
  background: rgba(255, 94, 94, 0.05);
}

.dbd-rule-warning {
  border-left-color: var(--amber);
  background: rgba(245, 166, 35, 0.05);
}

.dbd-rule-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}

.dbd-rule-header h4 {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
}

.dbd-rule-badge {
  background: transparent;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 11px;
  white-space: nowrap;
}

.dbd-rule-card p {
  margin: 0;
  font-size: 12px;
  color: var(--text2);
  line-height: 1.5;
}

.dbd-rule-cat {
  font-size: 11px;
  color: var(--text3);
  padding: 4px 8px;
  background: rgba(255,255,255,0.05);
  border-radius: 4px;
}

.dbd-rule-actions {
  display: flex;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.05);
}

/* ──── Buttons ──── */

.dbd-btn-sm,
.dbd-btn-xs {
  border: none;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  padding: 6px 12px;
  cursor: pointer;
  transition: all 0.2s;
  font-family: 'DM Sans', sans-serif;
}

.dbd-btn-xs {
  padding: 4px 8px;
  font-size: 11px;
}

.dbd-btn-ghost {
  background: transparent;
  color: var(--text2);
  border: 1px solid var(--border);
}

.dbd-btn-ghost:hover {
  background: rgba(255,255,255,0.05);
  color: var(--text);
  border-color: var(--border2);
}

.dbd-btn-primary {
  background: var(--accent);
  color: white;
}

.dbd-btn-primary:hover {
  background: var(--accent2);
}

.dbd-btn-danger {
  background: rgba(255, 94, 94, 0.1);
  color: var(--red);
  border: none;
}

.dbd-btn-danger:hover {
  background: rgba(255, 94, 94, 0.2);
}

/* Scrollbar */

.dbd-list-items::-webkit-scrollbar,
.dbd-table-detail::-webkit-scrollbar {
  width: 6px;
}

.dbd-list-items::-webkit-scrollbar-track,
.dbd-table-detail::-webkit-scrollbar-track {
  background: transparent;
}

.dbd-list-items::-webkit-scrollbar-thumb,
.dbd-table-detail::-webkit-scrollbar-thumb {
  background: var(--border2);
  border-radius: 3px;
}

.dbd-list-items::-webkit-scrollbar-thumb:hover,
.dbd-table-detail::-webkit-scrollbar-thumb:hover {
  background: var(--border2);
}

.dbd-detail-panel select.form-control,
.dbd-modal-body select.form-control{
  padding-right:34px;
  background-image:linear-gradient(45deg,transparent 50%,var(--text3) 50%),linear-gradient(135deg,var(--text3) 50%,transparent 50%);
  background-position:calc(100% - 18px) calc(50% - 2px), calc(100% - 12px) calc(50% - 2px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
}

.dbd-detail-panel .form-control::placeholder,
.dbd-detail-panel .form-input::placeholder,
.dbd-modal-body .form-control::placeholder,
.dbd-modal-body .form-input::placeholder{
  color:var(--text3);
}

.dbd-modal-body .form-label{
  margin-top:2px;
  margin-bottom:2px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:var(--text2);
}

.dbd-fields-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:12px 0 8px;}

.dbd-fields{display:flex;flex-direction:column;gap:6px;}

.dbd-field-row{display:grid;grid-template-columns:180px 1fr 1fr auto;gap:8px;align-items:start;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:8px;}

.dbd-field-row b{font-size:12px;}

.dbd-field-row small{display:block;font-size:10px;color:var(--text3);}

.dbd-field-row>div{font-size:11px;color:var(--text2);}

.dbd-row-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;}

.dbd-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;}

.dbd-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:7px;}

.dbd-card.danger{border-color:rgba(255,90,120,.42);box-shadow:0 0 0 1px rgba(255,90,120,.14) inset;}

.dbd-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;}

.dbd-card-head b{font-size:13px;}

.dbd-card-meta{font-size:11px;color:var(--text3);}

.dbd-card p{margin:0;font-size:12px;color:var(--text2);line-height:1.5;}

.dbd-status{
  display:inline-flex;
  align-items:center;
  padding:3px 8px;
  border-radius:999px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.03em;
  text-transform:uppercase;
  border:1px solid transparent;
}

.dbd-status.pub{background:rgba(74,222,128,.1);color:#7df0b1;border-color:rgba(74,222,128,.35);}

.dbd-status.draft{background:rgba(251,191,36,.1);color:#ffd27a;border-color:rgba(251,191,36,.35);}

.dbd-mark{
  display:inline-flex;
  align-items:center;
  padding:3px 8px;
  border-radius:999px;
  font-size:10px;
  font-weight:700;
  border:1px solid var(--border2);
  color:var(--text2);
  background:var(--surface3);
}

.dbd-mark.main{color:#8fd3ff;border-color:rgba(96,165,250,.38);background:rgba(96,165,250,.1);}

.dbd-mark.off{color:var(--green);border-color:rgba(74,222,128,.38);background:rgba(74,222,128,.1);}

.dbd-mark.rec{color:#c4b5fd;border-color:rgba(139,92,246,.38);background:rgba(139,92,246,.1);}

.dbd-chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px;}

.dbd-chip{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  border:1px solid var(--border2);
  background:var(--surface3);
  color:var(--text2);
  padding:3px 8px;
  font-size:10px;
  font-weight:600;
}

.dbd-errors{
  margin-top:2px;
  padding:8px 9px;
  border-radius:8px;
  border:1px solid rgba(255,130,130,.32);
  background:rgba(255,99,132,.08);
}

.dbd-errors b{display:block;font-size:11px;color:#ffb4b4;margin-bottom:4px;}

.dbd-errors ul{margin:0;padding-left:16px;display:flex;flex-direction:column;gap:3px;}

.dbd-errors li{font-size:11px;color:#ffd0d0;line-height:1.35;}

.dbd-sql{margin:0;padding:9px;background:#0e1220;border:1px solid rgba(255,255,255,.08);border-radius:8px;max-height:160px;overflow:auto;font-size:11px;color:#d7def6;}

.dbd-sql-input{min-height:130px;font-family:'DM Mono',monospace;}

.dbd-sql.hl .kw{color:#8cb6ff;font-weight:700;}

.dbd-sql.hl .tb{color:#67e8f9;font-weight:700;cursor:pointer;text-decoration:underline dotted rgba(103,232,249,.5);text-underline-offset:2px;}

.dbd-sql.hl .fd{color:#f9a8d4;cursor:pointer;text-decoration:underline dotted rgba(249,168,212,.5);text-underline-offset:2px;}

.dbd-sql.hl .tb:hover,.dbd-sql.hl .fd:hover{filter:brightness(1.15);}

.dbd-check-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:7px 10px;
  margin-top:2px;
}

.dbd-check-list label{
  display:flex;
  align-items:center;
  gap:7px;
  color:var(--text2);
  font-size:12px;
  border:1px solid var(--border2);
  background:var(--surface2);
  border-radius:8px;
  padding:7px 8px;
}

.dbd-check-list input{accent-color:var(--accent);}

.dbd-warn{border-color:rgba(255,130,130,.35)!important;}

.dbd-advanced-block{
  margin-top:4px;
  border:1px solid var(--border2);
  border-radius:10px;
  padding:8px 10px;
  background:var(--surface2);
}

.dbd-advanced-block summary{
  cursor:pointer;
  font-size:12px;
  font-weight:700;
  color:var(--text2);
  margin-bottom:6px;
}

.dbd-advanced-block[open] summary{color:var(--text);}

.dbd-tree{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.dbd-tree-node{
  border:1px solid var(--border2);
  border-radius:10px;
  background:var(--surface2);
  overflow:hidden;
}

.dbd-tree-btn{
  width:100%;
  border:none;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:10px;
  font-size:13px;
  font-weight:700;
}

.dbd-tree-btn:hover{background:var(--surface3);}

.dbd-tree-children{
  border-top:1px solid var(--border);
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.dbd-tree-leaf{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--surface3);
  padding:7px 8px;
  font-size:12px;
  color:var(--text2);
}

.dbd-tree-leaf button{
  border:none;
  background:transparent;
  color:var(--accent2);
  cursor:pointer;
  font-size:11px;
  font-weight:700;
}

.dbd-tree-leaf button:hover{filter:brightness(1.1);}

.dbd-diagram-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:10px;}

.dbd-diagram-canvas{position:relative;min-height:540px;background:linear-gradient(180deg,rgba(18,22,37,.56),rgba(11,15,27,.62));border:1px solid var(--border);border-radius:12px;overflow:hidden;}

.dbd-diagram-canvas svg{position:absolute;inset:0;width:100%;height:100%;}

.dbd-diagram-canvas line{stroke:rgba(169,183,223,.28);stroke-width:1.6;}

.dbd-diagram-canvas line.active{stroke:rgba(72,227,211,.78);stroke-width:2.2;}

.dbd-node{position:absolute;transform:translate(-50%,-50%);border:1px solid rgba(124,106,255,.35);background:rgba(16,20,34,.92);color:#eef2ff;border-radius:10px;padding:8px 10px;min-width:130px;text-align:left;cursor:pointer;box-shadow:0 8px 20px rgba(0,0,0,.28);}

.dbd-node b{display:block;font-size:12px;}

.dbd-node small{font-size:10px;color:#aeb9d7;}

.dbd-node.active{border-color:#48e3d3;box-shadow:0 0 0 1px rgba(72,227,211,.45),0 10px 24px rgba(0,0,0,.34);}

.dbd-diagram-side{display:flex;flex-direction:column;gap:8px;}

.dbd-diagram-side h3{margin:0;font-size:15px;}

.dbd-diagram-side p{margin:0;font-size:12px;color:var(--text2);line-height:1.5;}

.dbd-neigh{display:flex;flex-direction:column;gap:6px;margin-top:6px;}

.dbd-neigh b{font-size:12px;color:var(--text);}

.dbd-empty{padding:16px;font-size:12px;color:var(--text3);border:1px dashed var(--border2);border-radius:10px;background:var(--surface2);}

/* Desktop: módulos no rodapé, em linha horizontal */

@media (min-width:1025px){
  :root{ --sw:0px; }
  .sidebar-overlay,
  .mob-menu-btn{
    display:none !important;
  }
  #main-sidebar.sidebar{
    position:fixed;
    top:auto;
    bottom:12px;
    left:50%;
    right:auto;
    transform:translateX(-50%);
    width:auto;
    min-width:0;
    height:58px;
    border-right:none;
    border-top:none;
    border:1px solid rgba(255,255,255,.10);
    border-radius:16px;
    background:linear-gradient(180deg,rgba(42,45,52,.96) 0%, rgba(31,34,40,.96) 100%);
    box-shadow:0 10px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.05);
    backdrop-filter:blur(8px);
    z-index:20;
    flex-direction:row;
    align-items:center;
    padding:0 10px;
    overflow:hidden;
    transition:transform .24s ease, opacity .2s ease;
  }
  body.dock-collapsed #main-sidebar.sidebar{
    transform:translateX(-50%) translateY(88px);
    opacity:0;
    pointer-events:none;
  }
  #main-sidebar .logo,
  #main-sidebar .sidebar-footer,
  #main-sidebar .nav-section{
    display:none !important;
  }
  #main-sidebar .nav-group{
    display:flex;
    align-items:center;
    gap:4px;
    width:auto;
    overflow-x:auto;
    overflow-y:hidden;
    padding:0;
  }
  #main-sidebar .nav-item{
    width:40px;
    min-width:40px;
    height:40px;
    border-left:none;
    border-radius:10px;
    margin:0;
  }
  #main-sidebar .nav-icon{
    width:22px;
    height:22px;
  }
  #main-sidebar .nav-icon svg{
    width:20px;
    height:20px;
  }
  #main-sidebar .nav-icon i{
    font-size:20px;
  }
  #main-sidebar #quick-notes-nav{
    display:flex !important;
    align-items:center;
    gap:4px;
    margin-left:8px;
    padding-left:8px;
    border-left:1px solid rgba(255,255,255,.08);
  }
  .main{
    margin-left:0 !important;
    padding-bottom:84px;
  }
  body.dock-collapsed .main{
    padding-bottom:26px;
  }
  .nb-topbar{
    left:0 !important;
  }
  body.nb-open .main{
    margin-left:0 !important;
  }
  .dock-toggle-btn{
    position:fixed;
    right:16px;
    bottom:16px;
    left:auto;
    transform:none;
    z-index:21;
    width:28px;
    height:28px;
    padding:0;
    border-radius:8px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(30,33,40,.88);
    color:#cfd4dd;
    font-size:14px;
    font-weight:700;
    line-height:1;
    font-family:'DM Sans',sans-serif;
    cursor:pointer;
    backdrop-filter:blur(6px);
    transition:all .15s ease;
    display:flex;
    align-items:center;
    justify-content:center;
    opacity:.85;
  }
  .dock-toggle-btn:hover{
    color:#fff;
    border-color:rgba(255,255,255,.28);
    background:rgba(42,46,56,.95);
    opacity:1;
  }
}

@media (max-width:1024px){
  .dock-toggle-btn{display:none !important;}
}

.dbd-modal-body{display:flex;flex-direction:column;gap:6px;margin-top:8px;}

@media(max-width:980px){
  .dbd-layout,.dbd-diagram-layout{grid-template-columns:1fr;}
  .dbd-list{max-height:none;}
  .dbd-field-row{grid-template-columns:1fr;}
}
