/* ── RESET & TOKENS ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f7f5f0; --surface:#ffffff; --surface2:#f0ebe3;
  --ink:#1a1814; --ink-muted:#7a7570; --ink-faint:#c5c0b8;
  --accent:#2d6a4f; --accent-light:#d8f3dc; --accent-hover:#1b4332;
  --bullet:#a0998f; --line:#e8e4dc;
  --tag-bg:#e9f5ee; --tag-color:#2d6a4f;
  --tag-at-bg:#e8f4fd; --tag-at-color:#1a6fa0;
  --note-color:#9a9490; --bc-color:#9a9490;
  --danger:#c0392b; --danger-light:#fde8e8;
  --search-hl:#ffe082;
  --shadow:0 1px 4px rgba(0,0,0,.07);
  --radius:8px;
}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;font-size:15px;line-height:1.6;}
::selection{background:var(--accent-light)}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}


body.landing-page{background:var(--bg);color:var(--ink);}
.landing-shell{min-height:100vh;display:flex;flex-direction:column}
.landing-header{max-width:1120px;width:100%;margin:0 auto;padding:24px 24px 8px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.landing-header img {height: 64px;width: auto;display: block;transition: opacity 0.15s ease, transform 0.15s ease;}
.landing-header:hover img {opacity: 0.85;transform: scale(1.02);}
.landing-brand{font-family:'Lora',serif;font-size:34px;font-weight:500;color:var(--accent);letter-spacing:-.4px;text-decoration:none}
.landing-brand em{font-style:italic}
.landing-header-actions{display:flex;gap:10px;flex-wrap:wrap}
.landing-header-actions .tb-icon-btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.landing-main{flex:1;max-width:1120px;width:100%;margin:0 auto;padding:28px 24px 64px;display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.landing-copy h1{font-family:'Lora',serif;font-size:64px;line-height:1.02;letter-spacing:-1.2px;color:var(--ink);margin:0 0 18px}
.landing-copy p{font-size:19px;line-height:1.65;color:var(--ink-muted);margin:0 0 26px;max-width:620px}
.landing-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.landing-cta a{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.btn-primary{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:999px;padding:13px 22px;font-size:15px;font-weight:600;box-shadow:0 10px 24px rgba(45,106,79,.18)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.btn-secondary{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:13px 22px;font-size:15px;font-weight:600}
.btn-secondary:hover{background:var(--surface2)}
.landing-points{display:grid;gap:10px}
.landing-point{display:flex;align-items:flex-start;gap:10px;color:var(--ink);font-size:15px}
.landing-point-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:9px;flex:0 0 8px}
.landing-preview{background:linear-gradient(180deg,#fff,#fbf8f3);border:1px solid var(--line);border-radius:24px;box-shadow:0 18px 40px rgba(0,0,0,.08);padding:18px}
.preview-topbar{display:flex;gap:8px;padding-bottom:12px}
.preview-dot{width:10px;height:10px;border-radius:50%;background:#d7d0c7}
.preview-editor{background:#fff;border:1px solid #eee7de;border-radius:18px;padding:20px}
.preview-title{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px}
.preview-back{width:30px;height:30px;border-radius:10px;background:var(--surface2);color:var(--ink-muted);display:flex;align-items:center;justify-content:center;font-size:16px;flex:0 0 30px}
.preview-title strong{display:block;font-family:'Lora',serif;font-size:28px;color:var(--accent);font-weight:500}
.preview-title small{display:block;color:var(--note-color);font-style:italic;font-size:13px;line-height:1.4;margin-top:2px}
.preview-node{display:flex;gap:10px;align-items:flex-start;margin:10px 0;color:var(--ink);font-size:16px}
.preview-bullet{width:17px;height:17px;border-radius:50%;background:#d7d0c7;margin-top:4px;flex:0 0 17px}
.preview-node.indent-1{padding-left:28px}
.preview-node.indent-2{padding-left:56px}
.preview-note{padding-left:28px;color:var(--note-color);font-size:13px;font-style:italic;margin:-2px 0 4px}
.landing-section{max-width:1120px;width:100%;margin:0 auto;padding:0 24px 72px}
.landing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.landing-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:0 4px 14px rgba(0,0,0,.04)}
.landing-card h3{margin:0 0 10px;font-size:18px;color:var(--ink)}
.landing-card p{margin:0;color:var(--ink-muted);font-size:15px;line-height:1.6}
.landing-footer{max-width:1120px;width:100%;margin:0 auto;padding:0 24px 36px;color:var(--ink-faint);font-size:13px}
@media (max-width: 920px){
  .landing-main{grid-template-columns:1fr;gap:24px;padding-top:12px}
  .landing-copy h1{font-size:48px}
  .landing-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .landing-header{padding:18px 16px 8px}
  .landing-header img {height: 24px;}
  .landing-main{padding:16px 16px 56px}
  .landing-section{padding:0 16px 56px}
  .landing-footer{padding:0 16px 28px}
  .landing-brand{font-size:30px}
  .landing-copy h1{font-size:40px}
  .landing-copy p{font-size:17px}
  .landing-header-actions{display:none}
}





/* ── AUTH SCREEN ────────────────────────────────────────── */
#auth-screen{
  position:fixed;inset:0;z-index:500;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
}
#auth-screen.hidden{display:none}
.auth-box{
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:40px 44px;width:400px;max-width:95vw;
  box-shadow:0 12px 40px rgba(0,0,0,.10);
}
.auth-logo{
  font-family:'Lora',serif;font-size:26px;font-weight:500;color:var(--accent);
  text-align:center;margin-bottom:6px;letter-spacing:-.3px;
}
.auth-logo em{font-style:italic}
.auth-logo img{display:block;margin:0 auto;max-width:170px;width:100%;height:auto;object-fit:contain}
.account-popup-card .auth-logo img,.popup-card .auth-logo img{max-width:150px}
.auth-sub{text-align:center;color:var(--ink-muted);font-size:13px;margin-bottom:28px}
.auth-tabs{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-bottom:24px}
.auth-tab{
  flex:1;padding:9px;text-align:center;cursor:pointer;font-size:13px;font-weight:500;
  background:none;border:none;color:var(--ink-muted);transition:all .15s;
}
.auth-tab.active{background:var(--accent);color:#fff}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:12px;color:var(--ink-muted);margin-bottom:5px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}
.auth-field input{
  width:100%;padding:10px 14px;border:1px solid var(--line);border-radius:var(--radius);
  font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);outline:none;
  background:var(--bg);transition:border-color .2s;
}
.auth-field input:focus{border-color:var(--accent);background:#fff}
.auth-btn{
  width:100%;padding:11px;background:var(--accent);color:#fff;border:none;
  border-radius:20px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;
  cursor:pointer;transition:background .15s;margin-top:4px;
}
.auth-btn:hover{background:var(--accent-hover)}
.auth-err{color:var(--danger);font-size:13px;margin-top:10px;text-align:center;min-height:18px}

.auth-back { margin-top: 18px; text-align: center;}
.auth-back-btn {display: inline-block; font-size: 14px; color: #8f867c; text-decoration: none; transition: color 0.15s ease;}
.auth-back-btn:hover {color: #2d2a26;}

/* ── TOPBAR ─────────────────────────────────────────────── */
#topbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--surface);border-bottom:1px solid var(--line);
  height:50px;display:flex;align-items:center;gap:10px;padding:0 18px;
  box-shadow:var(--shadow);
  
  display:flex;
  align-items:center;
  
  
}
#logo{
  font-family:'Lora',serif;font-size:19px;font-weight:500;color:var(--accent);
  letter-spacing:-.3px;user-select:none;cursor:pointer;flex-shrink:0;white-space:nowrap;
}
#logo em{font-style:italic}

#logo img {
  height: 28px;
  width: auto;
  display: block;
  transition: opacity 0.15s ease, transform 0.15s ease;
}

#logo:hover img {
  opacity: 0.85;
  transform: scale(1.02);
}

#breadcrumb{
  display:flex;align-items:center;gap:3px;flex:1;overflow:hidden;
  font-size:13px;color:var(--bc-color);min-width:0;
}
.bc-sep{color:var(--ink-faint);flex-shrink:0}
.bc-item{
  cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  padding:2px 7px;border-radius:5px;transition:background .15s,color .15s;max-width:180px;
}
.bc-item:hover{background:var(--accent-light);color:var(--accent)}
.bc-item.current{color:var(--ink);font-weight:500;cursor:default}
.bc-item.current:hover{background:none}

#tag-filter-bar{
  display:flex;align-items:center;gap:6px;flex-shrink:0;
  max-width:320px;overflow-x:auto;padding:2px 0;
}
#tag-filter-bar::-webkit-scrollbar{height:3px}
.tf-chip{
  display:flex;align-items:center;gap:4px;
  background:var(--tag-bg);color:var(--tag-color);
  border:1px solid #b7e4c7;border-radius:20px;
  padding:3px 10px;font-size:12px;font-weight:500;white-space:nowrap;cursor:pointer;
  transition:background .15s;
}
.tf-chip.at{background:var(--tag-at-bg);color:var(--tag-at-color);border-color:#aad4f0}
.tf-chip .tf-x{font-size:14px;line-height:1;opacity:.6}
.tf-chip .tf-x:hover{opacity:1}

.search-wrap{
  display:flex;align-items:center;gap:5px;
  background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:4px 12px;
  transition:border-color .2s;flex-shrink:0;
}
.search-wrap:focus-within{border-color:var(--accent)}
#search-input{
  background:none;border:none;outline:none;
  font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);width:140px;
}
#search-input::placeholder{color:var(--ink-faint)}

.topbar-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.tb-icon-btn{
  background:none;border:1px solid var(--line);border-radius:8px;
  padding:5px 10px;font-size:13px;cursor:pointer;color:var(--ink-muted);
  transition:all .15s;white-space:nowrap;
}
.tb-icon-btn:hover{background:var(--surface2);color:var(--ink)}
#user-chip{
  display:flex;align-items:center;gap:6px;
  padding:4px 10px 4px 6px;border:1px solid var(--line);border-radius:20px;
  font-size:13px;color:var(--ink-muted);cursor:pointer;transition:all .15s;
}
#user-chip:hover{background:var(--surface2)}
.user-avatar{
  width:24px;height:24px;border-radius:50%;
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;flex-shrink:0;
}

#user-menu{position:relative}
.user-menu-popup{
  position:absolute;top:42px;right:0;min-width:220px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 28px rgba(0,0,0,.12);
  padding:6px;display:none;z-index:300;
}
.user-menu-popup.open{display:block}
.user-menu-header{padding:10px 12px 8px;border-bottom:1px solid var(--line);margin-bottom:6px}
.user-menu-title{font-size:13px;font-weight:600;color:var(--ink)}
.user-menu-sub{font-size:12px;color:var(--ink-muted);margin-top:2px;word-break:break-word}
.user-menu-item{
  width:100%;border:none;background:none;text-align:left;padding:10px 12px;border-radius:8px;
  font-size:14px;line-height:1.25;cursor:pointer;color:var(--ink);display:flex;align-items:center;gap:10px;
}
.user-menu-item:hover{background:var(--surface2)}
.user-menu-item.danger{color:var(--danger)}
.user-menu-item.danger:hover{background:var(--danger-light)}
.user-menu-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px}
.popup-overlay{position:fixed;inset:0;background:rgba(26,24,20,.24);display:none;align-items:center;justify-content:center;z-index:600}
.popup-overlay.open{display:flex}
.popup-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 48px rgba(0,0,0,.16);width:420px;max-width:92vw;padding:24px}
.popup-title{font-size:20px;font-weight:600;color:var(--ink);margin-bottom:8px}
.popup-sub{font-size:13px;color:var(--ink-muted);margin-bottom:18px}
.popup-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
.popup-btn{padding:10px 14px;border-radius:10px;border:1px solid var(--line);background:var(--surface);cursor:pointer;font-size:14px;color:var(--ink)}
.popup-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.popup-btn.primary:hover{background:var(--accent-hover)}
.popup-btn:hover{background:var(--surface2)}
.popup-err{color:var(--danger);font-size:13px;min-height:18px;margin-top:10px}

/* ── MAIN ───────────────────────────────────────────────── */
#main{max-width:760px;margin:0 auto;padding:74px 24px 120px}

#zoom-title-wrap{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:22px;
}

#zoom-title-box{
  flex:1;
  min-width:0;
}

#zoom-title{
  font-family:'Lora',serif;
  font-size:26px;
  font-weight:500;
  color:var(--ink);
  outline:none;
  line-height:1.3;
  min-height:34px;
  cursor:text;
  margin-bottom:4px;
}

#zoom-title:empty::before{
  content:attr(data-placeholder);
  color:var(--ink-faint);
  pointer-events:none;
}

#zoom-title-note{
  font-size:13px;
  color:var(--note-color);
  font-style:italic;
  line-height:1.5;
  min-height:18px;
  white-space:pre-wrap;
}

#zoom-title-note:empty{
  display:none;
}

#zoom-back-btn{
  border:none;
  background:transparent;
  cursor:pointer;
  color:var(--ink-faint);
  padding:6px;
  border-radius:8px;
  transition:all .15s;
  flex-shrink:0;
  margin-top:2px;
}

#zoom-back-btn:hover{
  background:var(--surface2);
  color:var(--ink);
}

/* ── TREE ───────────────────────────────────────────────── */
.node{position:relative;padding-left:30px;margin:0}
.node-row{display:flex;align-items:flex-start;position:relative;min-height:28px}

.node-actions{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:28px;flex:0 0 28px;margin-right:2px;opacity:0;pointer-events:none;
  transition:opacity .15s ease;
}
.node-row:hover .node-actions,.node-actions.open{opacity:1;pointer-events:auto}
.node-menu-btn{
  width:24px;height:24px;border:none;border-radius:7px;background:transparent;
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-faint);
  transition:background .15s ease,color .15s ease,opacity .15s ease;opacity:.95;
}
.node-menu-btn:hover{background:var(--surface2);color:var(--ink)}
.node-menu{
  position:absolute;top:28px;left:0;min-width:210px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 28px rgba(0,0,0,.12);
  padding:6px;z-index:1000;display:none;
}
.node-actions.open .node-menu{display:block}
.node-menu-item{
  width:100%;border:none;background:none;text-align:left;padding:10px 12px;border-radius:8px;
  font-size:14px;line-height:1.2;cursor:pointer;color:var(--ink);display:flex;align-items:center;gap:10px;
}
.node-menu-item:hover{background:var(--surface2)}
.node-menu-item.danger{color:var(--danger)}
.node-menu-item.danger:hover{background:var(--danger-light);color:var(--danger)}
.node-menu-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px}
.node-menu-label{flex:1;min-width:0}
.node-menu-sep{height:1px;background:var(--line);margin:6px 0}

.node>.children::before{
  content:'';position:absolute;left:-20px;top:0;bottom:8px;
  width:1px;background:var(--line);pointer-events:none;
}
.toggle-btn{
  position:absolute;left:-28px;top:6px;width:17px;height:17px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;border-radius:3px;color:var(--ink-faint);font-size:9px;
  transition:all .15s;user-select:none;flex-shrink:0;
}
.toggle-btn:hover{color:var(--accent);background:var(--accent-light)}
.toggle-btn.invisible{visibility:hidden;pointer-events:none}

.bullet{
  width:22px;height:22px;margin-top:4px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;transition:transform .15s;
}
.bullet:hover{transform:scale(1.35)}

.node-content{
  flex:1;outline:none;padding:3px 6px;border-radius:5px;
  white-space:pre-wrap;word-break:break-word;caret-color:var(--accent);
  min-height:24px;line-height:1.6;font-size:15px;transition:background .1s;
}
.node-content:focus{background:rgba(45,106,79,.04)}
.node-content:empty::before{content:attr(data-placeholder);color:var(--ink-faint);pointer-events:none}

.note-row{display:flex;padding-left:55px; margin-top: -10px; }
.note-row.hidden{display:none}
.node-note{
  flex:1;outline:none;padding:2px 6px 4px;font-size:13px;
  color:var(--note-color);font-style:italic;white-space:pre-wrap;word-break:break-word;min-height:20px;
}
.node-note:empty::before{content:'Notă...';color:var(--ink-faint);font-style:italic;pointer-events:none}

/* tags inline */
.tag-hash{
  display:inline-block;background:var(--tag-bg);color:var(--tag-color);
  border-radius:3px;padding:0 5px;font-size:12px;font-weight:500;cursor:pointer;
}
.tag-hash:hover{background:#b7e4c7}

/* Inline links and emails in node content */
.content-link {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: rgba(45,106,79,.35);
  text-underline-offset: 2px;
  cursor: pointer;
  border-radius: 2px;
  padding: 0 1px;
  transition: background .12s, color .12s;
}
.content-link:hover {
  background: var(--acl, #d8f3dc);
  text-decoration-color: var(--accent);
}
.content-email {
  color: #1a6fa0;
  text-decoration-color: rgba(26,111,160,.35);
}
.content-email:hover {
  background: #e8f4fd;
}

.children.collapsed>.node{display:none}
.collapsed-badge{
  display:inline-flex;align-items:center;
  font-size:11px;color:var(--ink-faint);background:var(--surface2);
  border:1px solid var(--line);border-radius:10px;padding:0 8px;margin-left:6px;
  cursor:pointer;transition:all .15s;user-select:none;
}
.collapsed-badge:hover{background:var(--accent-light);color:var(--accent)}

.node.done .node-content{text-decoration:line-through;color:var(--ink-faint)}
.hl{background:var(--search-hl);border-radius:2px}
.node.search-hidden{display:none!important}
.node.search-match .node-content{background:rgba(255,224,130,.2)}
.node.tag-hidden{display:none!important}
.node.tag-match .node-content{outline:1px solid #b7e4c7;border-radius:5px}

/* ── CONTEXT MENU ───────────────────────────────────────── */
#ctx-menu{
  position:fixed;z-index:999;background:var(--surface);
  border:1px solid var(--line);border-radius:10px;
  box-shadow:0 8px 28px rgba(0,0,0,.13);padding:4px;min-width:190px;display:none;
}
.ctx-item{
  display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:6px;
  cursor:pointer;font-size:13px;color:var(--ink);transition:background .1s;user-select:none;
}
.ctx-item:hover{background:var(--accent-light);color:var(--accent)}
.ctx-item.danger:hover{background:var(--danger-light);color:var(--danger)}
.ctx-sep{height:1px;background:var(--line);margin:3px 6px}
.ctx-item .sc{margin-left:auto;font-size:11px;color:var(--ink-faint);font-family:'JetBrains Mono',monospace}

/* ── FLOATING TOOLBAR ───────────────────────────────────── */
#floatbar{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%);
  background:var(--ink);border-radius:26px;padding:7px 14px;
  display:flex;align-items:center;gap:2px;
  box-shadow:0 8px 32px rgba(0,0,0,.22);z-index:90;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
#floatbar.visible{opacity:1;pointer-events:all}
.fb-btn{
  background:none;border:none;color:rgba(255,255,255,.65);
  padding:6px 10px;border-radius:18px;cursor:pointer;font-size:12.5px;
  display:flex;align-items:center;gap:4px;font-family:'DM Sans',sans-serif;
  transition:all .15s;white-space:nowrap;
}
.fb-btn:hover{background:rgba(255,255,255,.12);color:#fff}
.fb-sep{width:1px;height:18px;background:rgba(255,255,255,.15);margin:0 3px}

/* ── SHORTCUTS MODAL ────────────────────────────────────── */
#modal-overlay{
  position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.45);
  display:none;align-items:center;justify-content:center;
}
#modal-overlay.open{display:flex}
#sc-box{
  background:var(--surface);border-radius:14px;padding:30px 36px;
  width:500px;max-width:95vw;box-shadow:0 20px 60px rgba(0,0,0,.2);
}
#sc-box h2{font-family:'Lora',serif;font-size:20px;margin-bottom:18px}
.sc-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--line);font-size:13px}
.sc-row:last-child{border:none}
.sc-key{font-family:'JetBrains Mono',monospace;font-size:11px;background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:2px 7px;color:var(--ink-muted)}
.sc-close{display:block;margin:18px auto 0;background:var(--accent);color:#fff;border:none;border-radius:20px;padding:8px 26px;font-family:'DM Sans',sans-serif;font-size:14px;cursor:pointer}
.sc-close:hover{background:var(--accent-hover)}

/* ── TOAST ──────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:78px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:7px 18px;border-radius:20px;
  font-size:13px;z-index:300;opacity:0;pointer-events:none;
  transition:opacity .25s;white-space:nowrap;
}
#toast.show{opacity:1}

/* ── SYNC STATUS ────────────────────────────────────────── */
#sync-status{
  position:fixed;bottom:10px;right:14px;
  font-size:11px;color:var(--ink-faint);
  display:flex;align-items:center;gap:4px;z-index:50;
}
.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--ink-faint)}
.sync-dot.saving{background:#f39c12}
.sync-dot.ok{background:#27ae60}
.sync-dot.err{background:var(--danger)}

/* ── EMPTY HINT ─────────────────────────────────────────── */
#empty-hint{text-align:center;margin-top:60px;color:var(--ink-faint);font-size:14px;display:none}
#empty-hint.show{display:block}

.account-popup-overlay{position:fixed;inset:0;z-index:650;background:rgba(26,24,20,.24);display:none;align-items:center;justify-content:center}
.account-popup-overlay.open{display:flex}
.account-popup-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:40px 44px;width:400px;max-width:95vw;box-shadow:0 12px 40px rgba(0,0,0,.10)}
.account-popup-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.account-popup-btn{width:100%;padding:11px;background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:20px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}
.account-popup-btn:hover{background:var(--surface2)}
.account-popup-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.account-popup-btn.primary:hover{background:var(--accent-hover)}
.account-popup-btn.danger{color:var(--danger)}

#mobile-menu-btn{
  display:none;
  background:none;
  border:1px solid var(--line);
  border-radius:8px;
  width:36px;
  height:36px;
  align-items:center;
  justify-content:center;
  color:var(--ink-muted);
  cursor:pointer;
  transition:all .15s;
  flex-shrink:0;
}
#mobile-menu-btn:hover{
  background:var(--surface2);
  color:var(--ink);
}

#mobile-menu{
  position:fixed;
  top:58px;
  right:14px;
  min-width:220px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  box-shadow:0 12px 28px rgba(0,0,0,.12);
  padding:6px;
  z-index:250;
  display:none;
}
#mobile-menu.open{display:block}

.mobile-menu-item{
  width:100%;
  border:none;
  background:none;
  text-align:left;
  padding:11px 12px;
  border-radius:8px;
  font-size:14px;
  line-height:1.25;
  cursor:pointer;
  color:var(--ink);
  display:flex;
  align-items:center;
  gap:10px;
}
.mobile-menu-item:hover{
  background:var(--surface2);
}
.mobile-user-item{
  border-top:1px solid var(--line);
  margin-top:4px;
  padding-top:12px;
}
.mobile-user-avatar{
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:600;
  flex-shrink:0;
}
.mobile-user-name{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

@media (max-width: 820px){
  #topbar{
    gap:8px;
    padding:0 12px;
  }

  #breadcrumb,
  #tag-filter-bar,
  .topbar-actions{
    display:none;
  }

  #logo{
    flex:1;
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  
  #logo img {
    height: 24px;
  }

  .auth-logo{
    display:flex;
    justify-content:center;
    align-items:center;
    flex:1;
    min-width:0;
    overflow:hidden;
  }

  .auth-logo img{
    max-width:110px;
    width:100%;
    height:auto;
  }

  .account-popup-card .auth-logo img,
  .popup-card .auth-logo img{
    max-width:100px;
  }

  .search-wrap{
    flex:0 1 132px;
    min-width:0;
    padding:4px 10px;
  }

  #search-input{
    width:100%;
    min-width:0;
  }

  #mobile-menu-btn{
    display:inline-flex;
  }

  #main{
    padding:68px 16px 120px;
  }
}


/* ── GOOGLE AUTH ─────────────────────────────────────────── */
.auth-divider{
  display:flex;
  align-items:center;
  gap:12px;
  margin:16px 0 14px;
  color:var(--ink-faint);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.auth-divider::before,
.auth-divider::after{
  content:'';
  flex:1;
  height:1px;
  background:var(--line);
}
.auth-divider span{white-space:nowrap}
.google-auth-wrap{
  width:100%;
  margin-top:12px;
}

.google-auth-slot{
  width:100%;
  min-height:44px;
  display:flex;
  justify-content:center;
  align-items:center;
  overflow:visible;
}

.google-auth-slot > div{
  width:100% !important;
  max-width:100% !important;
  display:flex !important;
  justify-content:center;
}

.google-auth-slot iframe{
  max-width:100% !important;
}
.google-auth-note{
  margin:0;
  font-size:12px;
  color:var(--ink-muted);
  text-align:center;
}

@media (max-width:640px){
  .google-auth-wrap{
    margin-top:10px;
  }

  .google-auth-slot{
    justify-content:stretch;
  }

  .google-auth-slot > div{
    justify-content:stretch;
  }
}

/* ── SHARE MODAL ─────────────────────────────────────────── */
.share-modal-card {
  max-width: 480px;
  width: 95vw;
}

.popup-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.popup-close-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  color: var(--ink-muted);
  padding: 2px 6px;
  border-radius: 4px;
  transition: background .15s, color .15s;
}
.popup-close-btn:hover { background: var(--surface2); color: var(--ink); }

.popup-divider {
  border: none;
  border-top: 1px solid var(--line);
  margin: 4px 0 18px;
}

.share-section { margin-bottom: 18px; }

.share-section-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink-muted);
  letter-spacing: .4px;
  text-transform: uppercase;
  margin-bottom: 10px;
}

/* select reuses auth-field input styling */
.auth-select {
  width: 100%;
  padding: 10px 13px;
  border: 1px solid var(--line);
  border-radius: var(--r, 8px);
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  color: var(--ink);
  background: var(--bg);
  outline: none;
  cursor: pointer;
  transition: border-color .2s;
  appearance: auto;
}
.auth-select:focus { border-color: var(--accent); background: #fff; }

.share-success-text {
  font-size: 13px;
  color: var(--accent);
  min-height: 18px;
  margin-bottom: 4px;
  word-break: break-all;
}

.share-modal-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 6px;
}
.share-btn-primary { flex: 1; }

/* ── Share list (active shares) ─── */
.share-list-empty {
  font-size: 13px;
  color: var(--ink-muted);
  padding: 6px 0 10px;
}

.share-list-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
  font-size: 13px;
}
.share-list-row:last-child { border-bottom: none; }

.share-list-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.share-list-date {
  font-size: 11px;
  color: var(--ink-muted);
}

.share-list-btn {
  padding: 4px 10px;
  font-size: 12px;
  flex-shrink: 0;
}

.share-list-del {
  background: var(--danger-light);
  color: var(--danger);
  border-color: transparent;
}
.share-list-del:hover { background: #f9c6c6; border-color: transparent; }

/* ── Share legend ─── */
.share-legend {
  margin-top: 16px;
  padding: 12px;
  background: var(--bg);
  border-radius: 8px;
  border: 1px solid var(--line);
}

.share-legend-title {
  display: block;
  font-size: 12px;
  color: var(--ink-muted);
  margin-bottom: 8px;
}

.share-legend-items {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.share-legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--ink-muted);
}

.share-legend-icon { flex-shrink: 0; }

/* ── RECEIVED SHARE NODES ───────────────────────────────── */
.node-shared-received > .node-row {
  background: rgba(26, 111, 160, 0.04);
  border-radius: 6px;
  border-left: 3px solid #1a6fa0;
  padding-left: 6px;
  margin-left: -9px;
}
.node-shared-rw > .node-row {
  background: rgba(192, 57, 43, 0.04);
  border-left-color: #c0392b;
}

.node-note-shared {
  color: var(--ink-muted);
  font-size: 12px;
  font-style: italic;
  cursor: default;
  user-select: text;
}

/* ── SHARE LIST MESSAGE ─────────────────────────────────── */
.share-list-msg {
  font-size: 12px;
  color: var(--ink-muted);
  font-style: italic;
}

.share-list-err { color: var(--danger); }

/* ── DRAG AND DROP ──────────────────────────────────────── */

/* Bullet doubles as drag handle for own nodes */
.bullet-draggable {
  cursor: grab;
}
.bullet-draggable:active {
  cursor: grabbing;
}

/* Dragging state — semi-transparent, but keep pointer events so drag continues */
.node.dragging {
  opacity: .3;
}

/* Child drop highlight */
.node.drop-child-hl > .node-row {
  background: var(--accent-light, #d8f3dc);
  border-radius: 5px;
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}


.auth-secondary-actions{
  margin-top:10px;
  text-align:center;
}

.auth-text-btn{
  border:none;
  background:none;
  color:var(--accent);
  font:inherit;
  font-size:13px;
  cursor:pointer;
  padding:4px 0;
}

.auth-text-btn:hover{
  color:var(--accent-hover);
  text-decoration:underline;
}

.popup-success{
  color:#2d6a4f;
  font-size:13px;
  min-height:18px;
  margin-top:8px;
  text-align:center;
}

/* ═══════════════════════════════════════════════════════════
   SHARED.HTML — page-specific styles
   ═══════════════════════════════════════════════════════════ */

/* Owner info in topbar */
.shared-owner-info {
  font-size: 12px;
  color: var(--ink-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 200px;
}

/* Type badge color variants */
.shared-badge-pub  { color: #2d6a4f; }
.shared-badge-pro  { color: #1a6fa0; }
.shared-badge-prw  { color: #c0392b; }

/* Loading state */
.shared-loading {
  text-align: center;
  padding: 80px 24px;
  color: var(--ink-muted);
  font-size: 15px;
}

/* Auth gate wrapper */
.shared-auth-gate {
  max-width: 420px;
  margin: 40px auto 0;
}
.shared-auth-desc {
  font-size: 14px;
  color: var(--ink-muted);
  margin-bottom: 20px;
  line-height: 1.5;
}

/* Error box */
.shared-error {
  text-align: center;
  padding: 80px 24px;
  color: var(--danger);
}
.shared-error h2 {
  font-family: 'Lora', serif;
  font-size: 22px;
  margin-bottom: 10px;
}
.shared-error p {
  color: var(--ink-muted);
  font-size: 14px;
}

/* Meta info banner */
.shared-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  padding: 10px 14px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--ink-muted);
}
.shared-meta strong { color: var(--ink); }

/* Editable node content in writable share */
.node-content-editable {
  cursor: text;
  caret-color: var(--accent);
  transition: background .1s;
}
.node-content-editable:focus {
  background: rgba(45,106,79,.04);
  outline: none;
}
.node-content-editable:empty::before {
  content: attr(data-placeholder);
  color: var(--ink-faint);
  pointer-events: none;
}

/* Delete button on writable nodes */
.shared-del-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink-faint);
  padding: 2px 5px;
  border-radius: 3px;
  font-size: 13px;
  margin-left: 4px;
  margin-top: 4px;
  flex-shrink: 0;
  transition: color .15s;
}
.shared-del-btn:hover { color: var(--danger); }

/* Add sub-item button */
.shared-add-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 4px;
  margin-left: 22px;
  padding: 3px 10px;
  border: 1px dashed var(--ink-faint);
  border-radius: 6px;
  background: none;
  cursor: pointer;
  font-size: 12px;
  color: var(--ink-muted);
  font-family: 'DM Sans', sans-serif;
  transition: all .15s;
}
.shared-add-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-light);
}

/* Save banner (fixed bottom) */
.shared-save-banner {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--ink);
  padding: 14px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  z-index: 90;
  transform: translateY(100%);
  transition: transform .25s;
}
.shared-save-banner.show { transform: translateY(0); }
.shared-save-banner > span {
  color: rgba(255,255,255,.8);
  font-size: 14px;
}
.shared-save-banner .account-popup-btn {
  background: none;
  border-color: rgba(255,255,255,.3);
  color: rgba(255,255,255,.7);
  width: auto;
  padding: 8px 18px;
}
.shared-save-banner .account-popup-btn:hover {
  border-color: rgba(255,255,255,.7);
  color: #fff;
  background: none;
}
.shared-save-btn {
  width: auto !important;
  padding: 8px 22px !important;
}

/* ── LANDING STATS ───────────────────────────────────────── */
.landing-stats-section {
  padding-bottom: 48px;
}
.landing-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}
.landing-stat {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 20px 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
}
.landing-stat-val {
  font-family: 'Lora', serif;
  font-size: 32px;
  font-weight: 500;
  color: var(--accent);
  line-height: 1;
}
.landing-stat-label {
  font-size: 12px;
  color: var(--ink-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .4px;
}
@media (max-width: 640px) {
  .landing-stats-grid { max-width: 100%; gap: 10px; }
  .landing-stat-val { font-size: 26px; }
}
