/* ClearView Note v3 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0f1117;--surface:#181b23;--surface2:#1e2130;--border:#2a2d3a;
  --text:#f4f5f7;--sub:#c4c8d4;--accent:#20FDF0;--accent-dim:#16b8b2;
  --danger:#ef4444;--success:#22c55e;--warn:#f59e0b;
  --radius:8px;--sidebar-w:220px;--list-w:280px;
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;line-height:1.5}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
input,select,textarea,button{font-family:inherit;font-size:14px;color:inherit}

/* Logo SVG color */
.logo-svg{color:var(--accent)}

/* Topbar */
.topbar{display:flex;align-items:center;padding:0 16px;height:52px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;gap:8px;overflow:visible}
.topbar-left{display:flex;align-items:center;gap:10px;flex-shrink:0}
.topbar-nav{display:flex;align-items:center;gap:2px;flex:1;overflow:visible;flex-wrap:nowrap}
.topbar-nav-item{padding:5px 10px;border-radius:6px;color:var(--sub);font-size:13px;white-space:nowrap;transition:background .1s,color .1s;display:inline-flex;align-items:center;gap:5px;text-decoration:none;background:none;border:none;cursor:pointer;font-family:inherit;height:34px;flex-shrink:0}
.topbar-nav-item:hover{background:var(--surface2);color:var(--text);text-decoration:none}

/* Nav groups (dropdowns) */
.nav-group{position:relative;flex-shrink:0}
.nav-group-btn{user-select:none}
.nav-dropdown{display:none;position:absolute;top:calc(100% + 6px);left:0;min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.35);padding:4px;z-index:9999}
.nav-dropdown-right{left:auto;right:0}
.nav-dropdown.open{display:block;animation:ddFadeIn .12s ease}
@keyframes ddFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.nav-dd-item{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:6px;font-size:13px;color:var(--sub);text-decoration:none;transition:background .1s,color .1s;white-space:nowrap;width:100%;background:none;border:none;cursor:pointer;font-family:inherit}
.nav-dd-item:hover{background:var(--surface2);color:var(--text);text-decoration:none}
.nav-dd-divider{height:1px;background:var(--border);margin:4px 0}
.nav-dd-badge{margin-left:auto;background:var(--danger);color:#fff;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}
.nav-badge-inline{background:var(--danger);color:#fff;border-radius:10px;padding:1px 5px;font-size:10px;font-weight:700}
.topbar-right{display:flex;align-items:center;gap:4px;flex-shrink:0;position:relative}
.menu-toggle{background:none;border:none;color:var(--sub);cursor:pointer;padding:4px 6px;border-radius:4px;line-height:1;display:none}
.user-chip{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:3px 10px;font-size:13px;color:#dde0e8}
.topbar-brand{color:var(--text)}

/* Buttons */
.button{display:inline-flex;align-items:center;justify-content:center;padding:7px 14px;border-radius:var(--radius);border:none;cursor:pointer;font-weight:600;font-size:13px;transition:opacity .15s;text-decoration:none;gap:6px}
.button:hover{opacity:.85;text-decoration:none}
.button.primary{background:var(--accent);color:#000}
.button.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}
.button.ghost:hover{background:var(--surface2)}
.button.danger{background:var(--danger);color:#fff}
.button.full{width:100%}.button.small{padding:4px 10px;font-size:12px}
.button:disabled{opacity:.4;cursor:not-allowed}

/* App grid */
.app-grid{display:grid;grid-template-columns:var(--sidebar-w) var(--list-w) 1fr;height:calc(100vh - 52px);overflow:hidden;background:var(--bg)}

/* Sidebar */
.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
.sidebar-section{padding:12px;border-bottom:1px solid var(--border)}
.sidebar-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#c4c8d4;margin-bottom:6px}
.nav-item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:6px;color:var(--text);font-size:13px;cursor:pointer;transition:background .12s,color .12s;text-decoration:none}
.nav-item:hover{background:var(--surface2);color:var(--text);text-decoration:none}
.nav-item.active{background:var(--accent);color:#000;font-weight:600}
.nav-item span{background:var(--surface2);border-radius:10px;padding:1px 7px;font-size:11px}
.nav-item.active span{background:rgba(0,0,0,.2)}
.sidebar-stats{margin-top:auto;padding:10px 12px;font-size:11px;color:var(--sub);border-top:1px solid var(--border)}

/* Upcoming events */
.upcoming-event{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;border-left:3px solid var(--accent);margin-bottom:4px;text-decoration:none;font-size:12px;transition:background .1s}
.upcoming-event:hover{background:var(--surface2);text-decoration:none}
.ue-date{color:var(--sub);flex-shrink:0;font-size:11px;width:38px}
.ue-title{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* List panel */
.list-panel{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.panel-head{padding:10px;border-bottom:1px solid var(--border)}
.search-bar input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text);outline:none}
.search-bar input:focus{border-color:var(--accent)}
.sort-row{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.sort-row select{background:var(--bg);border:1px solid var(--border);color:#c4c8d4;border-radius:4px;padding:3px 6px;font-size:12px;outline:none}
.note-count{font-size:11px;color:var(--sub)}
.note-list{flex:1;overflow-y:auto}
.note-card{display:block;padding:12px;border-bottom:1px solid var(--border);cursor:pointer;text-decoration:none;transition:background .1s}
.note-card:hover{background:var(--surface2);text-decoration:none}
.note-card.active{background:var(--surface2);border-left:3px solid var(--accent)}
.note-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.note-card-head strong{color:var(--text);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:85%}
.note-snippet{font-size:12px;color:#b8bcc8;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:6px}
.note-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:#b8bcc8}
.status-pill{background:var(--surface2);border-radius:4px;padding:1px 6px;font-size:10px;text-transform:uppercase;letter-spacing:.04em}
.note-tags{margin-top:5px;display:flex;flex-wrap:wrap;gap:4px}
.note-tags span{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:10px;color:#c4c8d4}
.empty-card{padding:24px 12px;color:#c4c8d4;font-size:13px;text-align:center}
.flash-success{padding:8px 12px;background:rgba(34,197,94,.15);color:var(--success);font-size:12px}
.flash-error{padding:8px 12px;background:rgba(239,68,68,.15);color:var(--danger);font-size:12px}

/* Editor */
.editor-panel{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}
.editor-tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}
.etab{padding:10px 16px;font-size:13px;color:#c4c8d4;border-bottom:2px solid transparent;transition:color .1s;display:flex;align-items:center;gap:6px}
.etab:hover{color:var(--text);text-decoration:none}
.etab.active{color:var(--accent);border-bottom-color:var(--accent)}
.etab-count{background:var(--surface2);border-radius:10px;padding:1px 6px;font-size:10px}
.empty-editor{display:flex;align-items:center;justify-content:center;flex:1}
.empty-editor-inner{text-align:center;color:var(--sub)}
.empty-editor-inner h2{margin-bottom:8px;color:var(--text)}
.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;flex-wrap:wrap;gap:4px}
.toolbar-btn{background:transparent;border:1px solid var(--border);color:var(--text);border-radius:5px;padding:4px 10px;font-size:12px;cursor:pointer;transition:background .1s,color .1s;text-decoration:none;display:inline-flex;align-items:center}
.toolbar-btn:hover{background:var(--surface2);color:var(--text);text-decoration:none}
.danger-btn{color:var(--danger);border-color:rgba(239,68,68,.3)}.danger-btn:hover{background:rgba(239,68,68,.1)}
.editor-toolbar-right{display:flex;gap:4px;flex-wrap:wrap}
.editor-form{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:16px;gap:10px}
.editor-meta-row{display:flex;gap:8px}
.meta-row-2{display:flex;gap:8px;align-items:center}
.title-input{flex:1;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-size:18px;font-weight:700;padding:4px 0;outline:none}
.title-input:focus{border-bottom-color:var(--accent)}
.status-select{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:4px 8px;outline:none;font-size:12px}
.tags-input{flex:1;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--sub);padding:3px 0;outline:none;font-size:12px}
.tags-input:focus,.due-input:focus{border-bottom-color:var(--accent)}
.due-input{background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--sub);padding:3px 0;outline:none;font-size:12px;width:130px}
.editor-body{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}
.editor-body textarea{flex:1;background:transparent;border:none;color:var(--text);resize:none;outline:none;font-size:15px;line-height:1.7;font-family:'SF Mono','Fira Code',monospace;min-height:0}
.markdown-preview{flex:1;overflow-y:auto;font-size:15px;line-height:1.7;color:var(--text);padding-right:4px}
.markdown-preview h1,.markdown-preview h2,.markdown-preview h3{color:var(--text);margin:12px 0 6px}
.markdown-preview code{background:var(--surface);padding:1px 5px;border-radius:3px;font-size:13px}
.markdown-preview ul{padding-left:20px}
.markdown-preview a{color:var(--accent)}
.editor-footer{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border);flex-shrink:0}
.editor-stats{font-size:12px;color:var(--sub)}
.save-row{display:flex;align-items:center;gap:10px}
.autosave-status{font-size:12px;color:var(--sub)}

/* Tab panels (files, share) */
.tab-panel{padding:16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}
.tab-panel-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}

/* File upload */
.upload-form{margin-bottom:4px}
.upload-area{border:2px dashed var(--border);border-radius:8px;transition:border-color .2s}
.upload-area.drag-over{border-color:var(--accent)}
.upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;gap:8px;cursor:pointer;color:var(--sub);font-size:13px;text-align:center}
.upload-label:hover{color:var(--text)}
.upload-label svg{color:var(--sub)}
.upload-label small{font-size:11px;color:var(--border)}
.file-input-hidden{display:none}
.file-list{display:flex;flex-direction:column;gap:8px}
.file-item{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px}
.file-item-left{display:flex;align-items:center;gap:10px}
.file-icon{font-size:20px}
.file-name{color:var(--accent);font-size:13px;display:block}
.file-size{font-size:11px;color:var(--sub)}
.file-preview{margin-top:4px;border-radius:6px;overflow:hidden;max-height:200px}
.file-preview img{width:100%;height:100%;object-fit:contain;background:var(--surface2)}
.empty-files{color:#c4c8d4;font-size:13px;padding:16px 0;text-align:center}

/* Share */
.share-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px}
.share-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);margin-bottom:10px}
.share-form{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.share-form input[type=email]{flex:1;min-width:160px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text);outline:none}
.share-form input[type=email]:focus{border-color:var(--accent)}
.check-label{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--sub);cursor:pointer}
.share-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}
.share-row:last-child{border-bottom:none}
.badge-edit{background:rgba(34,197,94,.15);color:var(--success);border-radius:4px;padding:1px 7px;font-size:11px}
.badge-read{background:var(--surface2);color:var(--sub);border-radius:4px;padding:1px 7px;font-size:11px}
.share-link-box{display:flex;gap:8px;align-items:center}
.share-link-box input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--sub);font-size:12px;outline:none}

/* Calendar */
.page-wrap{padding:20px 24px;max-width:1100px;margin:0 auto}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.page-head-left h1{font-size:22px;margin-bottom:2px}
.page-head-left p{color:var(--sub);font-size:13px}
.cal-nav{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.cal-nav strong{font-size:16px;min-width:140px;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.cal-day-header{background:var(--surface);padding:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);text-align:center}
.cal-cell{background:var(--surface);padding:6px;min-height:110px;position:relative;display:flex;flex-direction:column;gap:3px;cursor:pointer;transition:background .1s}.cal-cell:hover{background:var(--surface2)}
.cal-empty{background:var(--bg)}
.cal-today .cal-day-num{background:var(--accent);color:#000;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.cal-day-num{font-size:12px;color:var(--sub);font-weight:600;margin-bottom:2px}
.cal-event{font-size:11px;padding:2px 5px;border-radius:3px;background:var(--surface2);border-left:3px solid var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;display:block}
.cal-event:hover{opacity:.8;text-decoration:none}
.cal-day-hint{font-size:10px;color:var(--border);margin-top:auto;text-align:right;opacity:0;transition:opacity .15s}.cal-cell:hover .cal-day-hint{opacity:1;color:var(--accent)}

/* Modals */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}
.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-head h3{font-size:16px}
.modal-close{background:none;border:none;color:var(--sub);cursor:pointer;font-size:16px;padding:4px}
.modal-box label{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.modal-box label span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--sub)}
.modal-box input,.modal-box select,.modal-box textarea{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);outline:none;width:100%}
.modal-box input:focus,.modal-box select:focus,.modal-box textarea:focus{border-color:var(--accent)}
.modal-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px}

/* Shared pages */
.shared-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.shared-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}
.shared-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.shared-card-head strong{color:var(--text);font-size:14px}
.shared-meta{display:flex;align-items:center;justify-content:space-between;margin-top:12px;font-size:12px;color:var(--sub)}
.shared-note-body{font-size:15px;line-height:1.8;white-space:pre-wrap;color:var(--text)}
.empty-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;text-align:center;color:var(--sub)}
.empty-page h2{color:var(--text)}

/* Auth */
body.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-width:100vw;background:var(--bg);padding:20px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;width:100%;max-width:420px;color:var(--text)}
.auth-card h2{color:#e8e9ec}
.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.auth-brand h1{font-size:18px;color:var(--text)}
.auth-card h2{font-size:20px;margin-bottom:6px}
.auth-sub{color:var(--sub);margin-bottom:20px;font-size:13px}
.auth-card label,.register-card label{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.auth-card label span,.register-card label span{font-size:12px;color:var(--sub);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.auth-card input,.register-card input{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:9px 12px;color:var(--text);outline:none;width:100%}
.auth-card input:focus,.register-card input:focus{border-color:#20FDF0}
.auth-links{margin-top:16px;font-size:13px;color:var(--sub);display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.field-error{font-size:12px;color:var(--danger);margin-top:-10px;margin-bottom:8px}
.hint{font-size:12px;color:#b8bcc8;margin-top:-8px;margin-bottom:12px}

/* Settings */
.settings-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:24px}
.tab-item{padding:8px 16px;color:#c4c8d4;font-size:13px;border-bottom:2px solid transparent;transition:color .1s;text-decoration:none}
.tab-item:hover{color:var(--text);text-decoration:none}
.tab-item.active{color:var(--accent);border-bottom-color:var(--accent)}
.settings-body h2{margin-bottom:20px;font-size:18px}
.settings-body label{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.settings-body label span{font-size:12px;color:#c4c8d4;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.settings-body input,.settings-body select{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:9px 12px;color:var(--text);outline:none;width:100%}
.settings-body input:focus{border-color:var(--accent)}
.settings-body input:disabled{opacity:.5;cursor:not-allowed}
.danger-box{background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:20px}
.danger-box h3{color:var(--danger);margin-bottom:8px}
.danger-box p{color:var(--sub);font-size:13px;margin-bottom:16px}

/* Admin */
.admin-wrap{max-width:900px;margin:0 auto;padding:24px 16px}
.admin-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:24px}
.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px;text-align:center}
.stat-card .num{font-size:32px;font-weight:900;color:var(--accent)}
.stat-card .lbl{font-size:12px;color:var(--sub);margin-top:4px;text-transform:uppercase;letter-spacing:.05em}
.user-table{width:100%;border-collapse:collapse}
.user-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);padding:8px 12px;border-bottom:1px solid var(--border)}
.user-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.user-table tr:hover td{background:var(--surface)}
.admin-badge{background:var(--accent);color:#000;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:700}
.user-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.inline-form{display:inline-flex;gap:6px;align-items:center}
.inline-form input[type=password]{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:4px 8px;color:var(--text);font-size:12px;width:130px;outline:none}

/* Alerts */
.alert{padding:10px 14px;border-radius:6px;font-size:13px;margin-bottom:14px}
.alert-danger{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.2)}
.alert-success{background:rgba(34,197,94,.1);color:var(--success);border:1px solid rgba(34,197,94,.2)}
.top-gap{margin-top:8px}

/* Mobile */
@media(max-width:900px){
  .topbar-nav{display:none}
  .menu-toggle{display:flex}
  .topbar-appname{display:none}
  .topbar-right .user-chip{display:none}
  .app-grid{display:flex;flex-direction:column;height:calc(100vh - 52px);overflow:hidden}
  .sidebar{position:fixed;left:-100%;top:52px;width:270px;height:calc(100vh - 52px);z-index:200;transition:left .25s cubic-bezier(.4,0,.2,1);box-shadow:6px 0 24px rgba(0,0,0,.4)}
  .sidebar.open{left:0}
  .list-panel{display:none}
  .editor-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
}

/* Mobile nav drawer */
.mobile-nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:299;backdrop-filter:blur(2px)}
.mobile-nav-overlay.open{display:block}
.mobile-nav-drawer{position:fixed;top:0;left:-100%;width:min(300px,85vw);height:100vh;background:var(--surface);z-index:300;display:flex;flex-direction:column;transition:left .28s cubic-bezier(.4,0,.2,1);box-shadow:8px 0 32px rgba(0,0,0,.5);overflow-y:auto}
.mobile-nav-drawer.open{left:0}
.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.mobile-nav-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px;color:var(--text)}
.mobile-nav-close{background:none;border:none;color:var(--sub);cursor:pointer;padding:6px;border-radius:6px;line-height:1}
.mobile-nav-close:hover{background:var(--surface2);color:var(--text)}
.mobile-nav-section{padding:8px 0}
.mobile-nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);padding:6px 16px 4px}
.mobile-nav-item{display:flex;align-items:center;gap:12px;padding:11px 16px;color:var(--text);text-decoration:none;font-size:14px;font-weight:500;transition:background .1s;border-left:3px solid transparent}
.mobile-nav-item:hover{background:var(--surface2);text-decoration:none}
.mobile-nav-item.accent{color:var(--accent);border-left-color:var(--accent)}
.mobile-nav-divider{height:1px;background:var(--border);margin:4px 0}
.mobile-nav-badge{background:var(--danger);color:#fff;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700;margin-left:auto}
@media(max-width:768px){
  /* Editor fills full screen on mobile */
  .editor-form{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:10px 12px;min-height:0}
  .editor-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
  .editor-body textarea{
    flex:1;
    min-height:0;
    font-size:16px !important; /* prevents iOS auto-zoom */
    line-height:1.6;
    resize:none;
  }
  .title-input{font-size:16px !important} /* prevents iOS auto-zoom */
  .editor-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0}
  .etab{padding:10px 12px;font-size:12px;white-space:nowrap;flex-shrink:0}
  .editor-toolbar{flex-wrap:wrap;gap:3px;padding:6px 10px;flex-shrink:0}
  .toolbar-btn{font-size:11px;padding:4px 8px}
  .editor-footer{padding:8px 12px;flex-shrink:0}
  .tab-panel{padding:14px;overflow-y:auto;flex:1}
  /* Prevent horizontal scroll on whole page */
  body{overflow-x:hidden}
}
@media(max-width:480px){
  .topbar{padding:0 10px;gap:6px}
  .topbar-brand img{width:22px;height:22px}
  .button.ghost.small{padding:4px 8px;font-size:11px}
  .notif-wrap{padding:16px 10px}
}
@media(max-width:600px){
  .cal-grid{grid-template-columns:repeat(7,1fr);font-size:11px}
  .cal-cell{min-height:60px;padding:4px}
  .cal-event{display:none}
  .admin-stats{grid-template-columns:1fr}
}

/* ── Notifications ───────────────────────────────────── */
.notif-bell{position:relative;font-size:18px;cursor:pointer;text-decoration:none;display:flex;align-items:center;padding:4px 6px;border-radius:6px;transition:background .1s}
.notif-bell:hover{background:var(--surface2);text-decoration:none}
.notif-count{position:absolute;top:-2px;right:-2px;background:var(--danger);color:#fff;border-radius:10px;padding:1px 5px;font-size:10px;font-weight:700;min-width:16px;text-align:center}
.nav-badge{background:var(--accent);color:#000;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700;margin-left:4px;vertical-align:middle}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);text-decoration:none;transition:background .1s;border-radius:0}
.notif-item:hover{background:var(--surface);text-decoration:none}
.notif-item.unread{background:rgba(32,253,240,.04);border-left:3px solid var(--accent)}
.notif-icon{font-size:20px;flex-shrink:0;width:32px;text-align:center}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:13px;color:var(--text);font-weight:600;margin-bottom:2px}
.notif-text{font-size:12px;color:#c4c8d4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px}
.notif-time{font-size:11px;color:var(--border)}

/* ── Comments ────────────────────────────────────────── */
.comment-form textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);outline:none;resize:vertical;font-size:13px;line-height:1.5}
.comment-form textarea:focus{border-color:var(--accent)}
.comment-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.comment-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px}
.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.comment-avatar{width:28px;height:28px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--accent);flex-shrink:0}
.comment-avatar.small{width:22px;height:22px;font-size:10px}
.comment-author{font-size:13px;color:var(--text)}
.comment-time{font-size:11px;color:#b8bcc8;margin-left:6px}
.comment-body{font-size:13px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word}
.comment-delete{background:none;border:none;color:var(--border);cursor:pointer;font-size:12px;padding:2px 5px;border-radius:4px;transition:color .1s}
.comment-delete:hover{color:var(--danger)}
.comment-reply{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);padding-left:12px}
.reply-form{display:flex;align-items:center;gap:6px;margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}
.reply-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:5px 10px;color:var(--text);outline:none;font-size:12px}
.reply-input:focus{border-color:var(--accent)}

/* ── Help section ────────────────────────────────────── */
.help-section{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--border)}
.help-section:last-child{border-bottom:none}
/* v1.0.62 — help-icon now hosts flat-color SVG icons (was emoji). */
.help-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--accent);background:rgba(32,253,240,.06);border:1px solid rgba(32,253,240,.18);border-radius:6px}
.help-icon svg{display:block}
.help-section h3{font-size:15px;color:var(--text);margin-bottom:10px}
.help-section p{font-size:13px;color:#c4c8d4;line-height:1.7;margin-bottom:8px}
.help-section p:last-child{margin-bottom:0}
.help-section strong{color:var(--text);font-weight:600}
.help-section code{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:12px;color:var(--accent);font-family:'SF Mono','Fira Code',monospace}

/* ── Note colors ─────────────────────────────────────── */
.note-color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}
.note-color-bar{width:4px;border-radius:2px;align-self:stretch;flex-shrink:0;margin-right:2px}

/* ── Note history ────────────────────────────────────── */
.history-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 14px}
.history-item-left{flex:1;min-width:0}
.history-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.history-meta{font-size:11px;color:var(--sub);margin-bottom:4px}
.history-preview{font-size:12px;color:var(--sub);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── Markdown checklist ──────────────────────────────── */
.md-check{display:flex;align-items:flex-start;gap:8px;margin:4px 0;cursor:pointer;color:var(--text);font-size:15px}
.md-check.checked{color:var(--sub);text-decoration:line-through}
.md-check input{margin-top:2px;accent-color:var(--accent)}

/* ── Offline banner ──────────────────────────────────── */
#offlineBanner{top:0!important}

/* ── Update toast ────────────────────────────────────── */
.update-toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--accent);color:#000;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:600;z-index:9999;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px rgba(0,0,0,.4)}

/* ── Light theme ─────────────────────────────────────── */
html.theme-light {
  --bg: #f0f2f5;
  --surface: #ffffff;
  --surface2: #e8eaef;
  --border: #cdd1db;
  --text: #111318;
  --sub: #4a5060;
  --accent: #0ea8a0;
  --accent-dim: #0d9690;
  --danger: #dc2626;
  --success: #15803d;
  --warn: #b45309;
}

/* Logo invert in light mode */
html.theme-light .topbar-brand img { filter: brightness(0); }

/* Topbar */
html.theme-light .topbar { background:#ffffff; border-bottom:1px solid #cdd1db; }
html.theme-light .topbar-nav-item { color:#4a5060; }
html.theme-light .topbar-nav-item:hover { background:#e8eaef; color:#111318; }
html.theme-light .nav-dropdown { box-shadow:0 8px 32px rgba(0,0,0,.12); }
html.theme-light .nav-dd-item { color:#555b6e; }
html.theme-light .nav-dd-item:hover { background:#f0f1f5; color:#111318; }
html.theme-light .user-chip { background:#e8eaef; border-color:#cdd1db; color:#4a5060; }
html.theme-light .theme-toggle { border-color:#cdd1db; color:#4a5060; }
html.theme-light .theme-toggle:hover { background:#e8eaef; color:#111318; }
html.theme-light .notif-bell { color:#4a5060; }
html.theme-light .button.ghost { border-color:#cdd1db; color:#111318; background:#ffffff; }
html.theme-light .button.ghost:hover { background:#e8eaef; }
html.theme-light .menu-toggle { color:#4a5060; }

/* Sidebar */
html.theme-light .sidebar { background:#ffffff; border-right:1px solid #cdd1db; }
html.theme-light .sidebar-section { border-bottom-color:#cdd1db; }
html.theme-light .sidebar-title { color:#4a5060; }
html.theme-light .sidebar-stats { color:#4a5060; border-top-color:#cdd1db; }
html.theme-light .nav-item { color:#4a5060; }
html.theme-light .nav-item:hover { background:#e8eaef; color:#111318; }
html.theme-light .nav-item.active { background:var(--accent); color:#ffffff; }
html.theme-light .nav-item.active span { background:rgba(0,0,0,.15); color:#fff; }
html.theme-light .upcoming-event { border-left-color:var(--accent); }
html.theme-light .upcoming-event:hover { background:#e8eaef; }
html.theme-light .ue-title { color:#111318; }

/* Note list panel */
html.theme-light .list-panel { background:#f9fafb; border-right:1px solid #cdd1db; }
html.theme-light .panel-head { border-bottom-color:#cdd1db; }
html.theme-light .search-bar input { background:#ffffff; border-color:#cdd1db; color:#111318; }
html.theme-light .search-bar input:focus { border-color:var(--accent); }
html.theme-light .sort-row select { background:#ffffff; border-color:#cdd1db; color:#4a5060; }
html.theme-light .note-count { color:#4a5060; }
html.theme-light .note-card { border-bottom:1px solid #e5e7eb; }
html.theme-light .note-card:hover { background:#f3f4f6; }
html.theme-light .note-card.active { background:#e6f7f6; border-left:3px solid var(--accent); }
html.theme-light .note-card-head strong { color:#111318; }
html.theme-light .note-snippet { color:#4a5060; }
html.theme-light .note-meta { color:#4a5060; }
html.theme-light .status-pill { background:#e8eaef; color:#4a5060; }
html.theme-light .note-tags span { background:#f0f2f5; border-color:#cdd1db; color:#4a5060; }
html.theme-light .empty-card { color:#4a5060; }
html.theme-light .flash-success { background:rgba(21,128,61,.1); color:#15803d; }
html.theme-light .flash-error { background:rgba(220,38,38,.1); color:#dc2626; }

/* Editor */
html.theme-light .editor-panel { background:#fafbfc !important; }
html.theme-light .editor-tabs { background:#ffffff; border-bottom:1px solid #cdd1db; }
html.theme-light .etab { color:#4a5060; border-bottom:2px solid transparent; }
html.theme-light .etab:hover { color:#111318; }
html.theme-light .etab.active { color:var(--accent); border-bottom-color:var(--accent); }
html.theme-light .etab-count { background:#e8eaef; color:#4a5060; }
html.theme-light .editor-toolbar { background:#ffffff; border-bottom:1px solid #cdd1db; }
html.theme-light .toolbar-btn { border-color:#cdd1db; color:#3a3d4a; background:#ffffff; }
html.theme-light .toolbar-btn:hover { background:#e8eaef; color:#111318; }
html.theme-light .danger-btn { color:#dc2626; border-color:rgba(220,38,38,.35); }
html.theme-light .danger-btn:hover { background:rgba(220,38,38,.08); }
html.theme-light .title-input { color:#111318; border-bottom-color:#cdd1db; }
html.theme-light .title-input:focus { border-bottom-color:var(--accent); }
html.theme-light .title-input::placeholder { color:#9aa0b0; }
html.theme-light .status-select { background:#ffffff; border-color:#cdd1db; color:#3a3d4a; }
html.theme-light .tags-input { color:#4a5060; border-bottom-color:#cdd1db; }
html.theme-light .tags-input::placeholder { color:#9aa0b0; }
html.theme-light .due-input { color:#4a5060; border-bottom-color:#cdd1db; }
html.theme-light .editor-body textarea { color:#111318; background:#fafbfc; caret-color:#111318; }
html.theme-light .editor-body textarea::placeholder { color:#9aa0b0; }
html.theme-light .editor-footer { border-top-color:#cdd1db; }
html.theme-light .editor-stats { color:#4a5060; }
html.theme-light .autosave-status { color:#4a5060; }
html.theme-light .empty-editor-inner { color:#4a5060; }
html.theme-light .empty-editor-inner h2 { color:#111318; }
html.theme-light .markdown-preview { color:#111318; }
html.theme-light .markdown-preview code { background:#e8eaef; color:#111318; }

/* Tab panels (files, share, comments, history) */
html.theme-light .tab-panel { background:#fafbfc; }
html.theme-light .tab-panel-title { color:#111318; }
html.theme-light .file-item { background:#ffffff; border-color:#cdd1db; }
html.theme-light .file-name { color:var(--accent); }
html.theme-light .file-size { color:#4a5060; }
html.theme-light .empty-files { color:#4a5060; }
html.theme-light .upload-area { border-color:#cdd1db; }
html.theme-light .upload-label { color:#4a5060; }
html.theme-light .upload-label small { color:#9aa0b0; }
html.theme-light .share-section { background:#ffffff; border-color:#cdd1db; }
html.theme-light .share-section-title { color:#4a5060; }
html.theme-light .share-form input[type=email] { background:#f0f2f5; border-color:#cdd1db; color:#111318; }
html.theme-light .share-link-box input { background:#f0f2f5; border-color:#cdd1db; color:#4a5060; }
html.theme-light .check-label { color:#4a5060; }
html.theme-light .share-row { border-bottom-color:#e5e7eb; }
html.theme-light .comment-item { background:#ffffff; border-color:#cdd1db; }
html.theme-light .comment-author { color:#111318; }
html.theme-light .comment-time { color:#4a5060; }
html.theme-light .comment-body { color:#111318; }
html.theme-light .comment-reply { border-top-color:#e5e7eb; }
html.theme-light .reply-input { background:#f0f2f5; border-color:#cdd1db; color:#111318; }
html.theme-light .comment-form textarea { background:#f0f2f5; border-color:#cdd1db; color:#111318; }
html.theme-light .history-item { background:#ffffff; border-color:#cdd1db; }
html.theme-light .history-title { color:#111318; }
html.theme-light .history-meta { color:#4a5060; }
html.theme-light .history-preview { color:#4a5060; }

/* Settings page */
html.theme-light .settings-tabs { border-bottom-color:#cdd1db; }
html.theme-light .tab-item { color:#4a5060; }
html.theme-light .tab-item:hover { color:#111318; }
html.theme-light .tab-item.active { color:var(--accent); border-bottom-color:var(--accent); }
html.theme-light .settings-body h2 { color:#111318; }
html.theme-light .settings-body label span { color:#4a5060; }
html.theme-light .settings-body input,
html.theme-light .settings-body select,
html.theme-light .settings-body textarea { background:#ffffff; border-color:#cdd1db; color:#111318; }
html.theme-light .settings-body input:focus { border-color:var(--accent); }
html.theme-light .settings-body input:disabled { background:#f0f2f5; color:#9aa0b0; }
html.theme-light .hint { color:#4a5060; }
html.theme-light .danger-box { background:rgba(220,38,38,.04); border-color:rgba(220,38,38,.2); }
html.theme-light .danger-box h3 { color:#dc2626; }
html.theme-light .danger-box p { color:#4a5060; }

/* Help section */
html.theme-light .help-section { border-bottom-color:#e5e7eb; }
html.theme-light .help-section h3 { color:#111318; }
html.theme-light .help-section p { color:#3a3d4a; }
html.theme-light .help-section strong { color:#111318; }
html.theme-light .help-section code { background:#e8eaef; border-color:#cdd1db; color:#0ea8a0; }

/* Chat */
html.theme-light .chat-sidebar { background:#ffffff; border-right:1px solid #cdd1db; }
html.theme-light .chat-sidebar-head { border-bottom-color:#cdd1db; }
html.theme-light .conv-item { border-bottom-color:#e5e7eb; }
html.theme-light .conv-item:hover { background:#f3f4f6; }
html.theme-light .conv-item.active { background:#e6f7f6; border-left-color:var(--accent); }
html.theme-light .conv-name { color:#111318; }
html.theme-light .conv-preview { color:#4a5060; }
html.theme-light .conv-time { color:#4a5060; }
html.theme-light .chat-header { background:#ffffff; border-bottom-color:#cdd1db; }
html.theme-light .chat-header-info h3 { color:#111318; }
html.theme-light .chat-header-info p { color:#4a5060; }
html.theme-light .chat-main { background:#f0f2f5 !important; }
html.theme-light .messages-area { background:#f0f2f5 !important; }
html.theme-light .msg-bubble { background:#ffffff; border-color:#cdd1db; color:#111318; }
html.theme-light .msg-row.mine .msg-bubble { background:var(--accent); color:#ffffff; border-color:var(--accent); }
html.theme-light .msg-sender { color:var(--accent); }
html.theme-light .msg-time { color:#4a5060; }
html.theme-light .day-divider { color:#4a5060; }
html.theme-light .day-divider::before { background:#cdd1db; }
html.theme-light .day-divider span { background:#f0f2f5; }
html.theme-light .chat-input-area { background:#ffffff; border-top-color:#cdd1db; }
html.theme-light .chat-input-row textarea { background:#f0f2f5; border-color:#cdd1db; color:#111318; }
html.theme-light .chat-input-row textarea::placeholder { color:#9aa0b0; }
html.theme-light .chat-input-row textarea:focus { border-color:var(--accent); }
html.theme-light .typing-indicator { color:#4a5060; }
html.theme-light .empty-chat h2 { color:#111318; }
html.theme-light .empty-chat p { color:#4a5060; }
html.theme-light .new-chat-section .sidebar-title { color:#4a5060; }
html.theme-light .user-pick { color:#4a5060; }
html.theme-light .user-pick:hover { background:#e8eaef; color:#111318; }

/* Modals */
html.theme-light .modal-overlay { background:rgba(0,0,0,.4); }
html.theme-light .modal-box { background:#ffffff; border-color:#cdd1db; }
html.theme-light .modal-head h3 { color:#111318; }
html.theme-light .modal-close { color:#4a5060; }
html.theme-light .modal-box label span { color:#4a5060; }
html.theme-light .modal-box input,
html.theme-light .modal-box select,
html.theme-light .modal-box textarea { background:#f0f2f5; border-color:#cdd1db; color:#111318; }

/* Connections */
html.theme-light .conn-card { background:#ffffff; border-color:#cdd1db; }
html.theme-light .conn-name { color:#111318; }
html.theme-light .conn-email { color:#4a5060; }
html.theme-light .conn-avatar { background:#e8eaef; }
html.theme-light .search-input { background:#ffffff; border-color:#cdd1db; color:#111318; }

/* Calendar */
html.theme-light .cal-grid { background:#cdd1db; border-color:#cdd1db; }
html.theme-light .cal-day-header { background:#f0f2f5; color:#4a5060; }
html.theme-light .cal-cell { background:#ffffff; }
html.theme-light .cal-cell:hover { background:#f3f4f6; }
html.theme-light .cal-today .cal-day-num { background:var(--accent); color:#ffffff; }
html.theme-light .cal-day-num { color:#4a5060; }
html.theme-light .cal-event { background:#e6f7f6; }
html.theme-light .cal-day-hint { color:#cdd1db; }
html.theme-light .cal-cell:hover .cal-day-hint { color:var(--accent); }
html.theme-light .cal-empty { background:#f9fafb; }

/* Notifications */
html.theme-light .notif-item { border-bottom-color:#e5e7eb; }
html.theme-light .notif-item:hover { background:#f9fafb; }
html.theme-light .notif-item.unread { background:rgba(14,168,160,.05); border-left-color:var(--accent); }
html.theme-light .notif-title { color:#111318; }
html.theme-light .notif-text { color:#4a5060; }
html.theme-light .notif-time { color:#9aa0b0; }

/* Shared */
html.theme-light .shared-card { background:#ffffff; border-color:#cdd1db; }
html.theme-light .shared-card-head strong { color:#111318; }
html.theme-light .shared-note-body { color:#111318; }
html.theme-light .empty-page h2 { color:#111318; }
html.theme-light .empty-page p { color:#4a5060; }

/* Auth pages in light mode */
html.theme-light.auth-page { background:#f0f2f5; }
html.theme-light .auth-card { background:#ffffff !important; border-color:#cdd1db; color:#111318 !important; }
html.theme-light .auth-brand h1 { color:#111318; }
html.theme-light .auth-card h2 { color:#111318; }
html.theme-light .auth-sub { color:#4a5060; }
html.theme-light .auth-card label span,
html.theme-light .register-card label span { color:#4a5060 !important; }
html.theme-light .auth-card input,
html.theme-light .register-card input { background:#f0f2f5 !important; border-color:#cdd1db; color:#111318 !important; }
html.theme-light .auth-links { color:#4a5060; }
html.theme-light .field-error { color:#dc2626; }

/* Admin */
html.theme-light .stat-card { background:#ffffff; border-color:#cdd1db; }
html.theme-light .user-table th { color:#4a5060; border-bottom-color:#cdd1db; }
html.theme-light .user-table td { border-bottom-color:#e5e7eb; color:#111318; }
html.theme-light .user-table tbody tr:hover td { background:#f3f4f6; }
html.theme-light .inline-form input { background:#f0f2f5; border-color:#cdd1db; color:#111318; }
html.theme-light .section-card { background:#ffffff; border-color:#cdd1db; }
html.theme-light .invite-row { border-bottom-color:#e5e7eb; }
html.theme-light .invite-form input[type=email] { background:#f0f2f5; border-color:#cdd1db; color:#111318; }

/* Page wrap text */
html.theme-light .page-head-left h1 { color:#111318; }
html.theme-light .page-head-left p { color:#4a5060; }

/* Alerts */
html.theme-light .alert-danger { background:rgba(220,38,38,.08); color:#dc2626; border-color:rgba(220,38,38,.2); }
html.theme-light .alert-success { background:rgba(21,128,61,.08); color:#15803d; border-color:rgba(21,128,61,.2); }

/* Buttons that need white text in light mode */
html.theme-light .button.primary { color:#000000; }
html.theme-light .button.danger { background:#dc2626; color:#ffffff; }

/* ── Encryption overlay ──────────────────────────────── */
.encrypt-overlay{position:absolute;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:4px}
.encrypt-overlay-inner{text-align:center;max-width:320px;padding:20px}
.encrypt-overlay-inner h3{font-size:16px;color:var(--text);margin-bottom:8px}
.encrypt-overlay-inner p{font-size:13px;color:var(--sub);margin-bottom:16px}

/* ── Theme toggle in topbar ──────────────────────────── */
.theme-toggle{background:none;border:1px solid var(--border);color:var(--sub);border-radius:20px;padding:3px 10px;font-size:13px;cursor:pointer;transition:background .1s}
.theme-toggle:hover{background:var(--surface2);color:var(--text)}

html.theme-light .page-wrap { background: var(--bg); color: var(--text); }
html.theme-light .admin-wrap { background: var(--bg); }
html.theme-light .settings-wrap { background: var(--bg); }
html.theme-light body { background: var(--bg); color: var(--text); }
html.theme-light .topbar strong { color: var(--text); }
html.theme-light .topbar-brand strong { color: var(--text) !important; }
html.theme-light h1, html.theme-light h2, html.theme-light h3 { color: var(--text); }
html.theme-light p { color: var(--sub); }
html.theme-light strong { color: var(--text); }

/* ── Light theme hard overrides ─────────────────────────────────────── */
html.theme-light { background:var(--bg) !important; color:var(--text) !important; }
html.theme-light body { background:var(--bg) !important; }
html.theme-light .app-grid { background:var(--bg) !important; }
html.theme-light .editor-panel { background:#fafbfc !important; }
html.theme-light .editor-body { background:#fafbfc !important; }
html.theme-light .editor-body textarea { background:#fafbfc !important; color:#111318 !important; }
html.theme-light .editor-form { background:#fafbfc !important; }
html.theme-light .editor-footer { background:#fafbfc !important; }
html.theme-light .chat-main { background:#f0f2f5 !important; }
html.theme-light .messages-area { background:#f0f2f5 !important; }
html.theme-light .chat-input-area { background:#ffffff !important; }
html.theme-light .chat-input-row textarea { background:#f0f2f5 !important; color:#111318 !important; }
html.theme-light .msg-bubble { background:#ffffff !important; color:#111318 !important; border-color:#cdd1db !important; }
html.theme-light .msg-row.mine .msg-bubble { background:var(--accent) !important; color:#ffffff !important; border-color:var(--accent) !important; }
html.theme-light .auth-card { background:#ffffff !important; color:#111318 !important; border-color:#cdd1db !important; }
html.theme-light body.auth-page { background:#f0f2f5 !important; }
html.theme-light .auth-card h2 { color:#111318 !important; }
html.theme-light .auth-card input, html.theme-light .register-card input { background:#f0f2f5 !important; color:#111318 !important; border-color:#cdd1db !important; }
html.theme-light .settings-body input, html.theme-light .settings-body select { background:#ffffff !important; color:#111318 !important; border-color:#cdd1db !important; }
html.theme-light .modal-box { background:#ffffff !important; color:#111318 !important; }
html.theme-light .modal-box input, html.theme-light .modal-box select, html.theme-light .modal-box textarea { background:#f0f2f5 !important; color:#111318 !important; }
html.theme-light .button.primary { background:var(--accent) !important; color:#000000 !important; }
html.theme-light .button.ghost { background:#ffffff !important; color:#111318 !important; border-color:#cdd1db !important; }
html.theme-light .button.danger { background:#dc2626 !important; color:#ffffff !important; }
html.theme-light .toolbar-btn { background:#ffffff !important; color:#3a3d4a !important; border-color:#cdd1db !important; }
html.theme-light .toolbar-btn:hover { background:#e8eaef !important; color:#111318 !important; }
html.theme-light .danger-btn { color:#dc2626 !important; background:transparent !important; border-color:rgba(220,38,38,.3) !important; }
html.theme-light .danger-btn:hover { background:rgba(220,38,38,.08) !important; }
html.theme-light .topbar { background:#ffffff !important; }
html.theme-light .sidebar { background:#ffffff !important; }
html.theme-light .list-panel { background:#f9fafb !important; }
html.theme-light .section-card, html.theme-light .share-section, html.theme-light .conn-card { background:#ffffff !important; border-color:#cdd1db !important; }
html.theme-light .stat-card { background:#ffffff !important; border-color:#cdd1db !important; }
html.theme-light .help-section { border-bottom-color:#e5e7eb !important; }
html.theme-light .help-section p { color:#3a3d4a !important; }
html.theme-light .help-section h3 { color:#111318 !important; }
html.theme-light .help-section strong { color:#111318 !important; }
html.theme-light .help-section code { background:#e8eaef !important; color:#0ea8a0 !important; border-color:#cdd1db !important; }
html.theme-light .cal-cell { background:#ffffff !important; }
html.theme-light .cal-day-header { background:#f0f2f5 !important; }
html.theme-light .notif-item { border-bottom-color:#e5e7eb !important; }
html.theme-light .search-input { background:#ffffff !important; border-color:#cdd1db !important; color:#111318 !important; }
html.theme-light .search-bar input { background:#ffffff !important; border-color:#cdd1db !important; color:#111318 !important; }
html.theme-light .sort-row select { background:#ffffff !important; border-color:#cdd1db !important; }
html.theme-light .status-select { background:#ffffff !important; border-color:#cdd1db !important; color:#3a3d4a !important; }
html.theme-light .note-card { border-bottom-color:#e5e7eb !important; }
html.theme-light .note-card.active { background:#e6f7f6 !important; }
html.theme-light .comment-item { background:#ffffff !important; border-color:#cdd1db !important; }
html.theme-light .comment-body { color:#111318 !important; }
html.theme-light .comment-form textarea { background:#f0f2f5 !important; color:#111318 !important; }
html.theme-light .reply-input { background:#f0f2f5 !important; color:#111318 !important; }
html.theme-light .history-item { background:#ffffff !important; border-color:#cdd1db !important; }
html.theme-light .file-item { background:#ffffff !important; border-color:#cdd1db !important; }
html.theme-light .title-input { color:#111318 !important; }
html.theme-light .tags-input { color:#4a5060 !important; }
html.theme-light .due-input { color:#4a5060 !important; }
html.theme-light h1, html.theme-light h2, html.theme-light h3 { color:#111318 !important; }

/* ── Bulk select ─────────────────────────────────────── */
.note-card-wrap { position: relative; }
.note-card-wrap:has(.bulk-check:checked) .note-card { background: rgba(32,253,240,.08) !important; border-left: 3px solid var(--accent); }
html.theme-light .note-card-wrap:has(.bulk-check:checked) .note-card { background: rgba(14,168,160,.08) !important; }

/* ── Reminder badge ──────────────────────────────────── */
.etab-count[style*="background:var(--warn)"] { background: var(--warn) !important; color: #000 !important; }

/* ── Template nav item ───────────────────────────────── */
.sidebar-section button.nav-item { width: 100%; text-align: left; background: none; border: none; cursor: pointer; font-family: inherit; }
.sidebar-section button.nav-item:hover { background: var(--surface2); color: var(--text); }

/* ── Chat bubble fixes ───────────────────────────────── */
.chat-layout { overflow-x: hidden !important; }
.chat-main { overflow-x: hidden !important; min-width: 0; }
.messages-area { overflow-x: hidden !important; }
.msg-row { max-width: 100%; overflow-wrap: break-word; word-break: break-word; }
.msg-row.mine { justify-content: flex-end; }
.msg-bubble { 
    max-width: min(520px, 65vw); 
    word-wrap: break-word; 
    overflow-wrap: break-word; 
    word-break: break-word;
    white-space: pre-wrap;
}
/* RTE-content (v1.0.51+) inside a bubble: inline images render bounded, paragraphs collapse cleanly */
.msg-bubble img { max-width: 100%; max-height: 340px; height: auto; border-radius: 8px; display: block; margin: 4px 0; cursor: zoom-in; }
/* Chat attachments — image strip + file badges below message bubble */
.msg-attachments { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.msg-attachments:first-child { margin-top: 0; }
.msg-att-img-link { display: inline-block; max-width: 100%; }
.msg-att-img-link img { max-width: 220px; max-height: 220px; border-radius: 8px; display: block; cursor: zoom-in; object-fit: cover; }
.msg-att-file { display: inline-flex; align-items: center; gap: 10px; padding: 8px 12px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; text-decoration: none; color: var(--text); max-width: 280px; transition: border-color .15s; }
.msg-att-file:hover { border-color: var(--accent); }
.msg-att-icon { font-size: 18px; flex-shrink: 0; }
.msg-att-meta { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.msg-att-name { font-size: 13px; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.msg-att-size { font-size: 11px; color: var(--sub); }
.msg-att-dl { color: var(--sub); font-size: 14px; flex-shrink: 0; }
.msg-att-file:hover .msg-att-dl { color: var(--accent); }
.msg-row.mine .msg-att-file { background: rgba(0,0,0,.12); border-color: rgba(0,0,0,.2); color: #000; }
.msg-row.mine .msg-att-file .msg-att-size { color: rgba(0,0,0,.6); }
.msg-bubble p { margin: 0 0 6px; }
.msg-bubble p:last-child { margin-bottom: 0; }
.msg-bubble ul, .msg-bubble ol { margin: 4px 0 4px 22px; padding: 0; }
.msg-bubble blockquote { margin: 4px 0; padding-left: 10px; border-left: 3px solid var(--border); color: var(--sub); }
.msg-bubble pre { background: var(--bg); padding: 6px 8px; border-radius: 6px; overflow-x: auto; margin: 4px 0; font-size: 12px; }
.msg-bubble code { background: var(--bg); padding: 1px 4px; border-radius: 3px; font-size: 12px; }
.msg-bubble a { color: var(--accent); text-decoration: underline; }
.msg-row.mine .msg-bubble { 
    background: var(--accent) !important; 
    color: #000 !important; 
    border-color: var(--accent) !important;
    font-weight: 500;
}
.msg-row:not(.mine) .msg-bubble {
    background: var(--surface) !important;
    color: var(--text) !important;
    border-color: var(--border) !important;
}
/* Consecutive messages from same user — tighten spacing */
.msg-row + .msg-row { margin-top: 2px; }
.msg-row.mine + .msg-row.mine .msg-avatar,
.msg-row:not(.mine) + .msg-row:not(.mine) .msg-avatar { visibility: hidden; }

.topbar-appname{font-size:14px;color:var(--text);font-weight:700}
.topbar-logout{display:inline-flex;align-items:center;gap:5px}
/* ── Toast Notifications ─────────────────────────────────────────────────── */
#cvn-toast-wrap{position:fixed;bottom:80px;right:24px;z-index:9000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.cvn-toast{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;font-size:13px;font-weight:600;color:var(--text);box-shadow:0 4px 20px rgba(0,0,0,.35);display:flex;align-items:center;gap:10px;pointer-events:all;max-width:320px;animation:toastIn .2s cubic-bezier(.4,0,.2,1)}
.cvn-toast.success{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.08)}
.cvn-toast.error{border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.08)}
.cvn-toast.info{border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.08)}
.cvn-toast-icon{font-size:16px;flex-shrink:0}
.cvn-toast-out{animation:toastOut .2s cubic-bezier(.4,0,.2,1) forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(20px)}}

/* ── Rich Text Editor ────────────────────────────────────────────────────── */
.rte-wrap{border:1px solid var(--border);border-radius:6px;overflow:hidden;background:var(--bg)}
.rte-wrap:focus-within{border-color:var(--accent)}
.rte-toolbar{display:flex;align-items:center;gap:2px;padding:5px 8px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}
.rte-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:5px;cursor:pointer;color:var(--sub);border:none;background:none;font-size:13px;font-weight:700;transition:background .1s,color .1s}
.rte-btn:hover,.rte-btn.active{background:var(--surface2);color:var(--text)}
.rte-sep{width:1px;height:18px;background:var(--border);margin:0 4px}
.rte-body{min-height:80px;padding:10px 12px;color:var(--text);font-size:13px;line-height:1.7;outline:none;overflow-y:auto}
.rte-body:empty::before{content:attr(data-placeholder);color:var(--sub);pointer-events:none}
.rte-body h1,.rte-body h2,.rte-body h3{color:var(--text);margin:8px 0 4px}
.rte-body h1{font-size:18px;font-weight:800}
.rte-body h2{font-size:15px;font-weight:700}
.rte-body h3{font-size:13px;font-weight:700}
.rte-body ul,.rte-body ol{padding-left:20px;margin:4px 0}
.rte-body li{margin:2px 0}
.rte-body code{background:var(--surface2);padding:1px 5px;border-radius:3px;font-family:ui-monospace,monospace;font-size:12px;color:var(--accent)}
.rte-body pre{background:var(--surface2);padding:10px;border-radius:6px;font-family:ui-monospace,monospace;font-size:12px;color:var(--accent);overflow-x:auto;margin:6px 0}
.rte-body blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--sub);margin:6px 0}
.rte-body a{color:var(--accent)}
.rte-body strong{color:var(--text)}

/* ── Inline Editing ──────────────────────────────────────────────────────── */
.inline-edit{cursor:text;border-radius:4px;padding:2px 5px;margin:-2px -5px;transition:background .1s}
.inline-edit:hover{background:var(--surface2)}
.inline-edit:focus{outline:2px solid var(--accent);background:var(--bg)}
.inline-edit[contenteditable=true]{outline:2px solid var(--accent);background:var(--bg);cursor:text}

/* ── Tag pills ───────────────────────────────────────────────────────────── */
.tag-pill{display:inline-flex;align-items:center;gap:4px;background:var(--surface2);color:var(--sub);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600;cursor:pointer;transition:background .1s}
.tag-pill:hover{background:var(--border);color:var(--text)}
.tag-pill.accent{background:rgba(32,253,240,.12);color:var(--accent)}
.tag-input-wrap{display:flex;flex-wrap:wrap;gap:4px;align-items:center;padding:4px 8px;background:var(--bg);border:1px solid var(--border);border-radius:6px;cursor:text;min-height:34px}
.tag-input-wrap:focus-within{border-color:var(--accent)}
.tag-input-wrap input{border:none;background:none;outline:none;font-size:12px;color:var(--text);min-width:80px;flex:1}

/* ── Task ID badge ───────────────────────────────────────────────────────── */
.task-id{font-size:10px;font-weight:700;color:var(--sub);font-family:ui-monospace,monospace;background:var(--surface2);padding:1px 5px;border-radius:3px;flex-shrink:0}

/* ── Pinned list star ────────────────────────────────────────────────────── */
.pin-star{cursor:pointer;color:var(--border);font-size:13px;transition:color .15s;background:none;border:none;padding:0;line-height:1}
.pin-star.pinned,.pin-star:hover{color:#f59e0b}

/* ── Focus mode ──────────────────────────────────────────────────────────── */
.focus-mode .topbar,.focus-mode .sidebar,.focus-mode .list-panel,.focus-mode .editor-toolbar,.focus-mode .note-meta{display:none!important}
.focus-mode .app-grid{grid-template-columns:0 0 1fr!important}
.focus-mode .editor-panel{background:var(--bg)}
.focus-mode .editor-body textarea{font-size:18px!important;line-height:1.9!important;max-width:720px;margin:0 auto;padding:40px 20px!important}
.focus-mode-btn{opacity:.5;transition:opacity .15s}.focus-mode-btn:hover{opacity:1}

/* ── Word count ──────────────────────────────────────────────────────────── */
.word-count{font-size:11px;color:var(--sub);padding:4px 70px 4px 12px;text-align:right;border-top:1px solid var(--border);background:var(--surface)}

/* ── Week calendar ───────────────────────────────────────────────────────── */
.week-grid{display:grid;grid-template-columns:60px repeat(7,1fr);flex:1;overflow:auto}
.week-time-col{border-right:1px solid var(--border)}
.week-time-slot{height:48px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;padding:2px 6px;font-size:10px;color:var(--sub)}
.week-day-col{border-right:1px solid var(--border);position:relative}
.week-day-head{padding:6px 4px;text-align:center;font-size:11px;font-weight:700;border-bottom:2px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:2}
.week-day-head.today{color:var(--accent)}
.week-event{position:absolute;left:2px;right:2px;border-radius:4px;padding:2px 5px;font-size:10px;font-weight:600;overflow:hidden;cursor:pointer;z-index:1}
.week-all-day-row{display:grid;grid-template-columns:60px repeat(7,1fr);border-bottom:2px solid var(--border);background:var(--surface);flex-shrink:0}

/* ── Burndown chart ──────────────────────────────────────────────────────── */
.burndown-wrap{position:relative;height:160px;margin-top:12px}
.burndown-svg{width:100%;height:100%}

/* ── Custom statuses ─────────────────────────────────────────────────────── */
.status-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:700;cursor:pointer;transition:opacity .1s}
.status-pill:hover{opacity:.8}

/* ── Paste image hints ───────────────────────────────────────────────────────── */
.paste-hint{font-size:11px;color:var(--sub);padding:3px 12px;opacity:.6}
.paste-hint kbd{background:var(--surface2);border:1px solid var(--border);border-radius:3px;padding:1px 5px;font-size:10px}
.note-img-preview{max-width:100%;border-radius:8px;margin:8px 0;display:block;border:1px solid var(--border)}
.chat-img-preview{max-width:300px;border-radius:8px;margin:4px 0;display:block;cursor:pointer}
.chat-img-preview:hover{opacity:.9}
/* Paste drop zone highlight */
.paste-active{outline:2px dashed var(--accent)!important;background:rgba(32,253,240,.04)!important}

/* ── v1.0.60: Design System — consistent button shapes + icon buttons ───── */
/* Standard buttons: 6px rounded rectangles. Use these classes anywhere
   instead of inline styles. Variants: .cv-btn (default), .cv-btn-primary
   (accent), .cv-btn-ghost (transparent w/ border), .cv-btn-danger. */
.cv-btn{display:inline-flex;align-items:center;gap:6px;background:var(--surface);color:var(--text);border:1px solid var(--border);padding:7px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;line-height:1.2;font-family:inherit}
.cv-btn:hover{background:var(--bg)}
.cv-btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#000;border:1px solid var(--accent);padding:7px 14px;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;text-decoration:none;line-height:1.2;font-family:inherit}
.cv-btn-primary:hover{filter:brightness(1.1)}
.cv-btn-ghost{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--text);border:1px solid var(--border);padding:7px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;line-height:1.2;font-family:inherit}
.cv-btn-ghost:hover{background:var(--surface)}
.cv-btn-danger{display:inline-flex;align-items:center;gap:6px;background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.4);padding:7px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;line-height:1.2;font-family:inherit}
.cv-btn-danger:hover{background:rgba(239,68,68,.08)}
.cv-btn-sm{padding:5px 10px;font-size:12px}
.cv-btn-lg{padding:10px 20px;font-size:14px}

/* Icon-only buttons: 28x28 rounded rectangles for SVG icons */
.cv-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;color:#a0a4b0;border:1px solid transparent;border-radius:6px;cursor:pointer;text-decoration:none;padding:0;transition:all .12s;font-family:inherit;vertical-align:middle}
.cv-icon-btn:hover{color:var(--accent);background:var(--surface);border-color:var(--border)}
.cv-icon-btn.danger:hover{color:#ef4444;border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.06)}
.cv-icon-btn[disabled],.cv-icon-btn.disabled{opacity:.35;pointer-events:none}
.cv-icon-btn svg{display:block}

/* Square status pills (v60 — was 12px round; now 6px square) */
.cv-status-pill{display:inline-block;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.cv-priority-pill{display:inline-block;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;color:#fff}
.cv-role-pill{display:inline-block;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ── v1.0.63 — Syncfusion EJ2 grid (Ticket Manager, ?view_mode=syncfusion) ──
   Scoped under #cv-ticket-grid so it can never affect any other view. Maps
   Syncfusion's material3-dark theme onto ClearView's dark surface + cyan
   accent palette. Detailed per-element overrides also live inline in
   includes/ticket_grid_syncfusion.php; these are the base guarantees. */
#cv-ticket-grid .e-grid{background:var(--bg);border:none;font-family:inherit;color:var(--text)}
#cv-ticket-grid .e-grid .e-gridheader,#cv-ticket-grid .e-grid .e-headercell{background:var(--surface);color:#a0a4b0;border-color:var(--border)}
#cv-ticket-grid .e-grid .e-rowcell{background:var(--bg);color:var(--text);border-color:var(--border)}
#cv-ticket-grid .e-grid .e-row:hover .e-rowcell{background:var(--surface2)}
#cv-ticket-grid .e-grid .e-toolbar,#cv-ticket-grid .e-grid .e-groupdroparea{background:var(--surface);border-color:var(--border)}
#cv-ticket-grid .e-grid .e-toolbar .e-tbar-btn{border-radius:6px;background:transparent}
#cv-ticket-grid .cv-sf-link{color:var(--text);text-decoration:none}
#cv-ticket-grid .cv-sf-link:hover{color:var(--accent)}
