/* ─── nodekasten v1 — UI styles ─────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Eye-friendly warm palette: cream/parchment, steel-blue accent,
     low-contrast text — reduces glare for long sessions. */
  --bg:        #ece6d6;
  --bg-2:      #efeadc;
  --bg-3:      #e2d9c0;
  --panel:     #f6f1e1;
  --line:      #d2c8ad;
  --acc:       #3a7ca5;
  --acc-soft:  #dfe9f0;
  --acc-2:     #5d8a4d;
  --warn:      #b8772d;
  --danger:    #b8483b;
  --text:      #3a342a;
  --muted:     #8a7e63;
  --font-h:    'Inter','Segoe UI',sans-serif;
  --font-s:    'Inter','Segoe UI',sans-serif;
  --font-b:    'Inter','Segoe UI',Tahoma,sans-serif;
  --radius:    10px;
  --shadow:    0 1px 2px rgba(80,60,30,.06), 0 4px 12px rgba(80,60,30,.05);
}

html,body{height:100%}
body{
  font-family:var(--font-b);background:var(--bg);color:var(--text);
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
a{color:var(--acc);text-decoration:none}
a:hover{text-decoration:underline}
button{font:inherit;cursor:pointer}

/* ─── AUTH PAGE ───────────────────────────────────────────── */
.auth-page{
  min-height:100vh;display:grid;place-items:center;
  background:
    radial-gradient(ellipse 60% 60% at 50% 10%, rgba(58,124,165,.08), transparent 70%),
    var(--bg);
  padding:32px 16px;
}
.auth-card{
  width:100%;max-width:400px;background:var(--panel);
  border:1px solid var(--line);border-radius:14px;
  padding:36px 32px;box-shadow:var(--shadow);
}
.auth-brand{text-align:center;margin-bottom:28px}
.auth-logo{
  width:54px;height:54px;margin:0 auto 12px;border-radius:14px;
  background:linear-gradient(135deg,var(--acc),#27607f);
  display:grid;place-items:center;
  font-family:var(--font-h);font-weight:700;font-size:18px;color:#fff;
  box-shadow:0 6px 18px rgba(58,124,165,.25);
}
.auth-brand h1{
  font-family:var(--font-h);font-size:20px;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;color:var(--text);
}
.auth-tag{font-family:var(--font-s);font-size:12px;color:var(--muted);margin-top:6px}
.auth-form label{
  display:block;font-family:var(--font-s);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--muted);margin:14px 0 4px;
}
.auth-form input{
  width:100%;background:var(--panel);border:1px solid var(--line);
  border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;
  transition:border-color .15s, box-shadow .15s;
}
.auth-form input:focus{
  outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(58,124,165,.15);
}
.auth-form button{
  width:100%;margin-top:18px;
  background:linear-gradient(135deg,var(--acc),#27607f);
  color:#fff;font-family:var(--font-s);letter-spacing:1px;font-weight:600;
  padding:11px;border:none;border-radius:8px;
  box-shadow:0 2px 6px rgba(58,124,165,.25);
  transition:transform .1s, box-shadow .15s;
}
.auth-form button:hover{box-shadow:0 4px 10px rgba(58,124,165,.35)}
.auth-form button:active{transform:translateY(1px)}
.auth-alt{text-align:center;margin-top:18px;font-size:13px;color:var(--muted)}
.auth-err{
  background:#f5e0db;border:1px solid #d8b3aa;color:#7e3328;
  padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:8px;
}
.auth-ok{
  background:#e6ecd9;border:1px solid #c1c9a4;color:#475c33;
  padding:14px 16px;border-radius:8px;font-size:14px;line-height:1.6;
}

/* White theme override for login/register — overrides the warm palette */
.auth-page{
  --panel:#ffffff;
  --line:#e2e8f0;
  --text:#1e293b;
  --muted:#64748b;
  background:#f1f5f9;
}
.auth-card{background:#ffffff;border-color:#e2e8f0}

/* Captcha widget — used on login/register/forgot-password */
.captcha-wrap{
  display:inline-block;background:#f8fafc;border:1px solid #cbd5e0;
  border-radius:6px;padding:4px;margin:6px 0;line-height:0;
}
.captcha-wrap svg{display:block}

/* Last-login banner on app.php — shown once per session */
.last-login-banner{
  position:fixed;top:10px;left:50%;transform:translateX(-50%);
  z-index:60;
  background:var(--panel);border:1px solid var(--line);border-radius:8px;
  padding:6px 12px;font-size:12px;color:var(--text);
  display:flex;align-items:center;gap:10px;
  box-shadow:0 4px 14px rgba(40,32,18,.18);
}
.last-login-banner button{
  background:transparent;border:none;color:var(--muted);
  font-size:16px;line-height:1;cursor:pointer;padding:0 2px;
}
.last-login-banner button:hover{color:var(--text)}

/* Language picker on auth pages — floats top-right */
.auth-lang{position:absolute;top:18px;right:18px;z-index:5}
.auth-lang select{
  background:#ffffff;border:1px solid #cbd5e0;border-radius:6px;
  padding:6px 10px;color:#1e293b;font-size:13px;font-family:inherit;
  cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.04);
}
.auth-lang select:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(58,124,165,.15)}

/* ─── APP SHELL ───────────────────────────────────────────── */
body.app{display:grid;grid-template-columns:280px 1fr;height:100vh;overflow:hidden}

.sidebar{
  background:var(--bg-2);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px 12px;overflow-y:auto;
}
.sb-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.sb-logo{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--acc),#27607f);
  display:grid;place-items:center;
  font-family:var(--font-h);font-weight:700;color:#fff;
  box-shadow:0 4px 10px rgba(58,124,165,.25);
}
.sb-title{font-family:var(--font-h);font-size:15px;font-weight:600;color:var(--text)}
.sb-sub{font-family:var(--font-s);font-size:12px;color:var(--muted)}
.sb-action{
  width:100%;background:linear-gradient(135deg,var(--acc),#27607f);
  color:#fff;border:none;padding:9px;border-radius:8px;
  font-family:var(--font-s);font-weight:600;margin-bottom:18px;
  box-shadow:0 2px 6px rgba(58,124,165,.2);
}
.sb-action:hover{box-shadow:0 4px 10px rgba(58,124,165,.3)}

.sb-section{margin-bottom:18px}
.sb-sec-head{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-s);font-size:11px;letter-spacing:1.5px;font-weight:600;
  text-transform:uppercase;color:var(--muted);
  padding:0 4px 6px;border-bottom:1px solid var(--line);margin-bottom:6px;
}
.sb-add{
  background:transparent;border:1px solid var(--line);
  width:20px;height:20px;border-radius:5px;color:var(--muted);
  display:grid;place-items:center;font-size:13px;
}
.sb-add:hover{color:var(--acc);border-color:var(--acc);background:var(--panel)}
.sb-list{display:flex;flex-direction:column;gap:1px}
.sb-item{
  padding:6px 8px;border-radius:6px;
  font-size:13px;color:var(--text);
  display:flex;align-items:center;gap:6px;cursor:pointer;
}
.sb-item:hover{background:var(--bg-3)}
.sb-item.active{background:var(--acc-soft);color:var(--acc);font-weight:500}
.sb-item .count{font-size:11px;color:var(--muted)}
.sb-item .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.sb-item .lbl{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-item .item-action{
  opacity:0;font-size:12px;color:var(--muted);background:none;border:none;
  padding:0 4px;border-radius:4px;line-height:1;
}
.sb-item:hover .item-action{opacity:.7}
.sb-item .item-action:hover{opacity:1;background:var(--bg-2)}
.sb-item .item-action.danger:hover{color:var(--danger)}

/* ─── Calendar widget ───────────────────────────────────── */
.calendar{font-family:var(--font-b);font-size:11px;user-select:none}
.cal-head{display:flex;align-items:center;justify-content:space-between;padding:4px 2px 6px}
.cal-head .cal-title{font-weight:600;color:var(--text);font-size:12px}
.cal-head button{
  background:transparent;border:1px solid var(--line);
  width:22px;height:22px;border-radius:5px;color:var(--muted);
  font-size:11px;line-height:1;display:grid;place-items:center;
}
.cal-head button:hover{color:var(--acc);border-color:var(--acc)}
.cal-grid{display:grid;grid-template-columns:repeat(7, 1fr);gap:1px}
.cal-dow{
  text-align:center;font-size:9px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.5px;padding:2px 0 4px;
}
.cal-cell{
  aspect-ratio:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  border-radius:5px;cursor:pointer;color:var(--text);
  position:relative;font-size:11px;
}
.cal-cell:hover{background:var(--bg-3)}
.cal-cell.out{color:var(--muted);opacity:.4}
.cal-cell.today{font-weight:700;color:var(--acc)}
.cal-cell.active{background:var(--acc);color:#fff}
.cal-cell.active.today{color:#fff}
.cal-cell.holiday{color:var(--danger);font-weight:600}
.cal-cell.holiday.active{color:#fff}
.cal-cell .has-dot{
  position:absolute;bottom:3px;width:4px;height:4px;
  border-radius:50%;background:var(--acc-2);
}
.cal-cell.active .has-dot{background:#fff}
.cal-hint{
  font-size:10px;color:var(--muted);text-align:center;
  padding:4px 2px 0;line-height:1.4;
}
.cal-hint a{color:var(--muted);text-decoration:underline}
.cal-hint a:hover{color:var(--acc)}

.cal-country-row{
  display:flex;align-items:center;gap:6px;
  padding:6px 2px 2px;font-size:11px;
}
.cal-country-lbl{
  font-family:var(--font-s);font-size:9px;letter-spacing:1px;font-weight:600;
  text-transform:uppercase;color:var(--muted);flex-shrink:0;
}
#cal-country{
  flex:1;background:var(--panel);border:1px solid var(--line);border-radius:5px;
  padding:3px 6px;color:var(--text);font-size:11px;font-family:inherit;cursor:pointer;
}
#cal-country:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 2px rgba(58,124,165,.12)}

.holidays-list{margin-top:8px;display:flex;flex-direction:column;gap:1px}
.holidays-list .hl-head{
  font-family:var(--font-s);font-size:10px;letter-spacing:1px;font-weight:600;
  text-transform:uppercase;color:var(--muted);padding:0 4px 4px;
  border-bottom:1px solid var(--line);margin-bottom:4px;
}
.holidays-list .hl-item{
  display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:5px;
  font-size:11px;color:var(--text);cursor:pointer;line-height:1.3;
}
.holidays-list .hl-item:hover{background:var(--bg-3)}
.holidays-list .hl-item.active{background:var(--acc-soft);color:var(--acc)}
.holidays-list .hl-date{
  flex-shrink:0;width:22px;text-align:center;font-weight:700;
  color:var(--danger);font-size:11px;
}
.holidays-list .hl-item.active .hl-date{color:var(--acc)}
.holidays-list .hl-name{
  flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

.sb-footer{
  margin-top:auto;padding-top:12px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:4px;
}
.sb-link{font-size:12px;color:var(--muted);padding:6px 8px;border-radius:6px}
.sb-link:hover{color:var(--acc);background:var(--panel);text-decoration:none}

/* ─── MAIN AREA ───────────────────────────────────────────── */
.main{display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden}
.topbar{
  display:flex;align-items:center;gap:12px;
  padding:8px 18px;border-bottom:1px solid var(--line);background:var(--bg-2);
}
.btn-menu{
  display:none;
  background:transparent;border:1px solid var(--line);border-radius:6px;
  color:var(--text);width:34px;height:32px;font-size:16px;line-height:1;
  align-items:center;justify-content:center;
}
.btn-menu:hover{background:var(--panel);border-color:var(--acc);color:var(--acc)}
.topbar input[type=search]{
  flex:1;max-width:480px;background:var(--panel);border:1px solid var(--line);
  border-radius:8px;padding:8px 12px;color:var(--text);font-size:13px;
}
.topbar input[type=search]:focus{
  outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(58,124,165,.12);
}
.topbar-status{margin-left:auto;font-size:11px;color:var(--muted);letter-spacing:.5px}

.btn-save{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--bg-2);border:1px solid var(--line);
  color:var(--muted);
  border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600;
  font-family:inherit;
  transition:background .15s, color .15s, border-color .15s, box-shadow .15s;
}
.btn-save[disabled]{opacity:.55;cursor:default}
.btn-save:not([disabled]){cursor:pointer}
.btn-save.dirty{
  background:linear-gradient(135deg,var(--acc),#27607f);
  color:#fff;border-color:var(--acc);
  box-shadow:0 2px 6px rgba(58,124,165,.25);
  animation:btnSavePulse 1.6s ease-in-out infinite;
}
.btn-save.dirty:hover{box-shadow:0 4px 10px rgba(58,124,165,.4)}
@keyframes btnSavePulse{
  0%,100%{box-shadow:0 2px 6px rgba(58,124,165,.25)}
  50%    {box-shadow:0 2px 12px rgba(58,124,165,.55)}
}
.btn-save-icon{font-size:13px;line-height:1}

.cols{display:grid;grid-template-columns:340px 1fr;overflow:hidden;position:relative}

/* Note list */
.note-list-wrap{border-right:1px solid var(--line);background:var(--panel);overflow-y:auto;display:flex;flex-direction:column}
.note-list-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:6px 12px;border-bottom:1px solid var(--line);
  background:var(--bg-2);position:sticky;top:0;z-index:3;
  font-size:11px;color:var(--muted);
}
.nlh-count{font-family:var(--font-s);letter-spacing:.5px;font-weight:600;text-transform:uppercase;font-size:10px}
.nlh-sort{display:inline-flex;align-items:center;gap:5px;color:var(--muted)}
.nlh-sort > span{font-size:12px}
.nlh-sort select{
  background:var(--panel);border:1px solid var(--line);border-radius:5px;
  padding:3px 6px;color:var(--text);font-size:11px;
  font-family:inherit;
}
.nlh-sort select:focus{outline:none;border-color:var(--acc)}
.note-list{display:flex;flex-direction:column;flex:1}
.note-item{
  padding:14px 16px;border-bottom:1px solid var(--line);
  cursor:pointer;transition:background .15s;
}
.note-item:hover{background:var(--bg-2)}
.note-item.active{background:var(--acc-soft);border-left:3px solid var(--acc);padding-left:13px}
.note-item .ni-title{
  font-family:var(--font-s);font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;
}
.note-item .ni-snippet{
  font-size:12px;color:var(--muted);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;max-height:36px;line-height:1.4;
}
.note-item .ni-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:10px;color:var(--muted);margin-top:6px;letter-spacing:.5px;
}
.note-item .ni-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:1px 7px;border-radius:10px;
  background:var(--bg-2);border:1px solid var(--line);
  font-size:10px;color:var(--muted);
}
.note-item .ni-badge .dot{width:6px;height:6px;border-radius:50%}
.note-list-empty{padding:32px;text-align:center;color:var(--muted);font-size:13px}

/* Editor */
.editor-wrap{display:grid;overflow:hidden}
.editor-empty{
  display:grid;place-items:center;text-align:center;color:var(--muted);padding:40px;
}
.editor-empty .ee-big{
  font-family:var(--font-h);font-size:18px;font-weight:600;
  color:var(--text);margin-bottom:8px;
}
.editor-empty .ee-sub{font-size:13px}

.editor-pane{
  display:grid;grid-template-rows:auto auto 1fr;
  overflow:hidden;background:var(--panel);
}
.note-title{
  border:none;background:transparent;
  font-family:var(--font-h);font-size:24px;font-weight:700;
  color:var(--text);padding:6px 24px 2px;width:100%;
}
.note-title:focus{outline:none}

.note-meta{
  display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;
  padding:6px 24px 10px;border-bottom:1px solid var(--line);
}
.meta-field{display:flex;flex-direction:column;gap:3px;min-width:130px;flex:1;max-width:220px}
.meta-field-wide{max-width:none;flex-basis:100%}
.meta-field span{
  font-family:var(--font-s);font-size:10px;letter-spacing:1px;
  text-transform:uppercase;color:var(--muted);font-weight:600;
}
.meta-field input, .meta-field select{
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  padding:5px 8px;color:var(--text);font-size:13px;
}
.meta-field input:focus, .meta-field select:focus{
  outline:none;border-color:var(--acc);box-shadow:0 0 0 2px rgba(58,124,165,.12);
}
.meta-actions{margin-left:auto;display:flex;align-items:flex-end}

/* Period (date range) row */
.period-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.period-allday{
  display:inline-flex;align-items:center;gap:4px;
  font-size:12px;color:var(--text);cursor:pointer;
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  padding:4px 8px;
}
.period-allday input{margin:0;cursor:pointer}
.period-row input[type=date],
.period-row input[type=datetime-local]{
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  padding:4px 6px;color:var(--text);font-size:12px;font-family:inherit;
}
.period-row input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 2px rgba(58,124,165,.12)}
.period-sep{color:var(--muted);font-size:13px}
.period-clear{
  background:transparent;border:1px solid var(--line);border-radius:6px;
  width:24px;height:24px;color:var(--muted);font-size:14px;line-height:1;
  display:grid;place-items:center;cursor:pointer;
}
.period-clear:hover{color:var(--danger);border-color:var(--danger)}

/* Chips (group + user shares) */
.chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding-top:2px}
.chip{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--acc-soft);color:var(--acc);
  border:1px solid var(--acc);border-radius:14px;
  padding:2px 4px 2px 10px;font-size:12px;font-weight:500;
}
.chip-kind{
  font-size:9px;letter-spacing:1px;font-weight:600;
  color:var(--muted);text-transform:uppercase;
  background:var(--panel);padding:1px 5px;border-radius:8px;margin-right:2px;
}
.chip-user{background:var(--bg-3);color:var(--text);border-color:var(--muted)}
.chip-user .chip-x{color:var(--muted)}
.chip-user .chip-x:hover{background:var(--muted);color:#fff}
.chip-x{
  background:transparent;border:none;
  color:var(--acc);font-size:14px;line-height:1;
  cursor:pointer;padding:0 6px;border-radius:50%;
}
.chip-x:hover{background:var(--acc);color:#fff}
.chip-add{
  background:var(--panel);border:1px dashed var(--line);
  border-radius:14px;padding:3px 10px;font-size:12px;
  color:var(--muted);cursor:pointer;
}
.chip-add:focus{outline:none;border-color:var(--acc);color:var(--acc)}
.chip-empty{color:var(--muted);font-size:12px;font-style:italic}
.chip-add-user-input{font-family:inherit;font-size:12px;color:var(--text);width:170px;outline:none}

#quill-host{overflow-y:auto;background:var(--panel);grid-row:3;grid-column:1}
.html-editor{
  grid-row:3;grid-column:1;
  width:100%;height:100%;
  padding:18px 24px;
  font-family:monospace;font-size:13px;line-height:1.65;
  background:var(--panel);color:var(--text);
  border:none;resize:none;outline:none;
  overflow-y:auto;
}
.btn-html-toggle{
  font-size:11px;padding:3px 8px;border-radius:4px;
  background:var(--panel);border:1px solid var(--line);
  color:var(--muted);cursor:pointer;font-family:inherit;
  transition:border-color .15s,color .15s,background .15s;
}
.btn-html-toggle:hover,.btn-html-toggle.html-active{
  border-color:var(--acc);color:var(--acc);background:var(--acc-soft);
}
.ql-toolbar.ql-snow{
  background:var(--bg-2);border:1px solid var(--line);border-radius:6px;
  padding:5px 10px;line-height:1;min-height:0;
  display:flex;flex-wrap:wrap;gap:2px 4px;align-items:center;
  flex-basis:100%;          /* take full row inside the .note-meta flex container */
  order:0;                  /* sits where inserted: between reminders and actions */
}
.ql-toolbar.ql-snow .ql-formats{
  margin-right:6px;vertical-align:middle;line-height:1;
  display:inline-flex;align-items:center;gap:2px;
  padding-right:6px;border-right:1px solid var(--line);
}
.ql-toolbar.ql-snow .ql-formats:last-child{border-right:none;margin-right:0}
.ql-toolbar.ql-snow button{
  width:22px;height:22px;padding:2px;margin:0;border-radius:4px;
  display:inline-flex;align-items:center;justify-content:center;
}
.ql-toolbar.ql-snow button:hover{background:var(--bg-3)}
.ql-toolbar.ql-snow button svg{width:14px;height:14px}
.ql-toolbar.ql-snow .ql-picker-label{padding:0 18px 0 5px;height:22px;line-height:22px;font-size:11px}
.ql-toolbar.ql-snow .ql-picker{height:22px;font-size:11px}
.ql-toolbar.ql-snow .ql-picker-options{padding:4px 6px;font-size:12px}
.ql-toolbar.ql-snow .ql-color-picker .ql-picker-label,
.ql-toolbar.ql-snow .ql-icon-picker .ql-picker-label{width:22px;padding:2px 4px}
.ql-toolbar.ql-snow .ql-color-picker .ql-picker-options{width:152px;padding:5px}
.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item{
  width:16px;height:16px;border:1px solid var(--line);margin:1px;
}
.ql-container.ql-snow{border:none;font-family:var(--font-b);font-size:15px;color:var(--text)}
.ql-editor{min-height:300px;padding:18px 24px;line-height:1.65}
.ql-editor.ql-blank::before{color:var(--muted);font-style:normal}
.ql-snow .ql-stroke{stroke:var(--muted)}
.ql-snow .ql-fill{fill:var(--muted)}
.ql-snow .ql-picker{color:var(--muted)}
.ql-snow .ql-active .ql-stroke,
.ql-snow button:hover .ql-stroke{stroke:var(--acc)}
.ql-snow .ql-active .ql-fill,
.ql-snow button:hover .ql-fill{fill:var(--acc)}
.ql-snow .ql-picker-options{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)}

/* Buttons */
.btn-danger{
  background:var(--panel);color:var(--danger);
  border:1px solid #d8b3aa;border-radius:6px;padding:6px 12px;font-size:12px;
}
.btn-danger:hover{background:#f5e0db}
.btn-warn{
  background:var(--panel);color:var(--warn);
  border:1px solid #d8bd91;border-radius:6px;padding:6px 12px;font-size:12px;
}
.btn-warn:hover{background:#f5ead2}
.btn-go{
  background:linear-gradient(135deg,var(--acc-2),#43662f);
  color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;
}

/* ─── ADMIN ───────────────────────────────────────────────── */
body.admin-page{background:var(--bg);min-height:100vh;display:flex;flex-direction:column}
.admin-bar{
  display:flex;align-items:center;gap:20px;
  padding:12px 22px;background:var(--panel);border-bottom:1px solid var(--line);
}
.admin-brand{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-h);font-size:14px;font-weight:600;color:var(--text);
}
.admin-logo{
  width:32px;height:32px;border-radius:8px;
  background:linear-gradient(135deg,var(--acc),#27607f);
  color:#fff;display:grid;place-items:center;font-weight:700;
}
.admin-nav{display:flex;gap:4px}
.admin-nav a{
  color:var(--text);padding:6px 12px;border-radius:6px;
  font-family:var(--font-s);font-size:13px;font-weight:500;
}
.admin-nav a:hover{background:var(--bg-2);text-decoration:none}
.admin-nav a.active{background:var(--acc-soft);color:var(--acc)}
.admin-user{margin-left:auto;font-size:12px;color:var(--muted)}
.admin-main{padding:24px 30px;max-width:1200px;width:100%;margin:0 auto}
.admin-main h1{
  font-family:var(--font-h);font-size:22px;font-weight:700;
  color:var(--text);margin-bottom:18px;
}
.admin-main h2{
  font-family:var(--font-h);font-size:14px;font-weight:600;
  color:var(--text);margin:28px 0 12px;
}

.adm-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px}
.adm-card{
  background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:18px;text-decoration:none;color:var(--text);
  box-shadow:var(--shadow);
  transition:border-color .15s, transform .15s;
}
.adm-card:hover{border-color:var(--acc);text-decoration:none;transform:translateY(-1px)}
.adm-card.warn{border-color:#d8bd91;background:#f5ead2}
.adm-card .adm-num{font-family:var(--font-h);font-size:28px;font-weight:700;color:var(--acc)}
.adm-card.warn .adm-num{color:var(--warn)}
.adm-card .adm-lbl{
  font-family:var(--font-s);font-size:11px;letter-spacing:1px;
  text-transform:uppercase;color:var(--muted);font-weight:600;
}

.adm-table{
  width:100%;border-collapse:collapse;background:var(--panel);
  border:1px solid var(--line);border-radius:10px;overflow:hidden;
  margin-top:8px;box-shadow:var(--shadow);
}
.adm-table th,.adm-table td{
  padding:10px 14px;text-align:left;
  border-bottom:1px solid var(--line);font-size:13px;
}
.adm-table th{
  font-family:var(--font-s);font-size:11px;letter-spacing:1px;
  text-transform:uppercase;color:var(--muted);font-weight:600;
  background:var(--bg-2);
}
.adm-table tbody tr:last-child td{border-bottom:none}
.adm-table tbody tr:hover{background:var(--bg-2)}
.row-actions{white-space:nowrap}
.row-actions form{margin-right:4px}

.adm-filters{display:flex;gap:8px;margin:6px 0 16px}
.adm-filters a{
  padding:6px 12px;border-radius:6px;font-size:12px;
  background:var(--panel);border:1px solid var(--line);color:var(--text);
}
.adm-filters a.active{background:var(--acc-soft);color:var(--acc);border-color:var(--acc)}
.adm-flash{
  background:#e6ecd9;border:1px solid #c1c9a4;color:#475c33;
  padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:13px;
}
.role{
  font-family:var(--font-s);font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;padding:2px 8px;border-radius:10px;
  border:1px solid var(--line);
}
.quota-bar{
  margin-top:4px;width:120px;height:5px;background:var(--bg-3);
  border-radius:3px;overflow:hidden;
}
.quota-fill{height:100%;border-radius:3px;transition:width .25s}
.role-admin{color:var(--acc);border-color:var(--acc)}
.role-vip{color:var(--warn);border-color:var(--warn);background:rgba(184,119,45,.1)}
.role-user{color:var(--muted)}
.status{
  font-family:var(--font-s);font-size:11px;letter-spacing:1px;
  text-transform:uppercase;padding:2px 8px;border-radius:10px;font-weight:600;
}
.status-pending{color:var(--warn);background:#f5ead2}
.status-approved{color:var(--acc-2);background:#e6ecd9}
.status-disabled{color:var(--danger);background:#f5e0db}
.tag-self{
  font-size:10px;color:var(--muted);
  border:1px solid var(--line);padding:1px 5px;border-radius:8px;margin-left:4px;
}
.muted{color:var(--muted)}
.cat-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle}

/* ─── Theme editor (admin) ───────────────────────────────── */
.theme-swatch{
  display:inline-block;width:18px;height:18px;border-radius:4px;
  border:1px solid var(--line);margin-right:2px;vertical-align:middle;
}
.theme-edit{
  background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:18px;box-shadow:var(--shadow);
}
.te-row{display:flex;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.te-field{flex:1;min-width:200px;display:flex;flex-direction:column;gap:4px}
.te-field span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.te-field input{
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  padding:8px;color:var(--text);font-size:13px;font-family:inherit;
}
.te-vars{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.te-var{border:1px solid var(--line);border-radius:8px;padding:8px;background:var(--bg-2)}
.te-var-head{font-size:11px;color:var(--muted);margin-bottom:6px}
.te-var-head code{font-size:10px;color:var(--acc);background:var(--panel);padding:1px 4px;border-radius:3px}
.te-var-row{display:flex;gap:6px;align-items:center}
.te-var-row input[type=color]{width:30px;height:30px;padding:0;border:1px solid var(--line);border-radius:4px;background:none}
.te-var-row input[type=text]{
  flex:1;font-family:monospace;font-size:12px;
  background:var(--panel);border:1px solid var(--line);border-radius:5px;
  padding:5px 7px;color:var(--text);
}
.te-actions{margin-top:16px;display:flex;gap:8px;justify-content:flex-end;align-items:center}
.te-actions a{text-decoration:none}

.te-preview{
  display:grid;grid-template-columns:160px 1fr;
  background:var(--bg);border:1px solid var(--line);border-radius:10px;
  overflow:hidden;margin-top:6px;
  color:var(--text);font-family:var(--font-b);
}
.tep-sb{background:var(--bg-2);padding:18px;color:var(--muted);border-right:1px solid var(--line);font-weight:600}
.tep-main{background:var(--panel);padding:18px}
.tep-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px}
.tep-main a{color:var(--acc)}
.tep-badge{
  display:inline-block;background:var(--acc-soft);color:var(--acc);
  padding:2px 8px;border-radius:10px;font-size:11px;margin-right:6px;
}
.tep-btn{
  background:var(--acc);color:#fff;border:none;border-radius:6px;
  padding:6px 12px;font-size:12px;margin-top:8px;cursor:default;
}

/* ─── User settings page ─────────────────────────────────── */
.set-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.set-card{
  background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:18px;box-shadow:var(--shadow);
}
.set-card-wide{grid-column:1/-1}
.set-card h2{font-size:14px;font-weight:600;color:var(--text);margin:0 0 12px}
.set-muted{color:var(--muted);font-size:13px;margin-bottom:8px}
.set-form label{
  display:block;font-size:11px;color:var(--muted);
  text-transform:uppercase;letter-spacing:1px;font-weight:600;
  margin:10px 0 4px;
}
.set-form input, .set-form select{
  width:100%;background:var(--panel);border:1px solid var(--line);
  border-radius:6px;padding:8px 10px;color:var(--text);font-size:13px;font-family:inherit;
}
.set-form input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 2px rgba(58,124,165,.12)}
.set-form button{margin-top:14px}
.smtp-log{
  background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  padding:12px;margin-top:8px;font-family:monospace;font-size:12px;
  color:var(--muted);white-space:pre-wrap;overflow-x:auto;max-height:300px;
}

.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.theme-card{
  border:2px solid var(--line);border-radius:10px;padding:6px;
  cursor:pointer;text-align:center;background:var(--panel);
  display:flex;flex-direction:column;gap:6px;transition:border-color .15s;
}
.theme-card input{display:none}
.theme-card.active{border-color:var(--acc);box-shadow:0 0 0 3px rgba(58,124,165,.12)}
.theme-card:hover{border-color:var(--acc)}
.tc-preview{
  border-radius:6px;padding:10px;height:60px;
  display:flex;align-items:center;justify-content:center;
}
.tc-panel{
  width:100%;height:100%;border-radius:5px;
  display:flex;align-items:center;justify-content:space-between;padding:0 10px;
}
.tc-title{font-weight:700;font-size:18px}
.tc-acc{width:18px;height:18px;border-radius:50%}
.tc-label{font-size:12px;color:var(--text);font-weight:500}

/* ─── Modal ──────────────────────────────────────────────── */
.modal{position:fixed;inset:0;z-index:50;display:grid;place-items:center}
.modal[hidden]{display:none}
.modal-back{position:absolute;inset:0;background:rgba(40,32,18,.35)}
.modal-panel{
  position:relative;background:var(--panel);
  border:1px solid var(--line);border-radius:12px;
  box-shadow:0 12px 40px rgba(40,32,18,.25);
  width:min(560px,92vw);max-height:88vh;overflow:auto;padding:0;
}
.modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;border-bottom:1px solid var(--line);
}
.modal-head h3{font-size:15px;font-weight:600;color:var(--text);margin:0}
#modal-close{
  background:transparent;border:none;width:28px;height:28px;border-radius:6px;
  color:var(--muted);font-size:18px;line-height:1;cursor:pointer;
}
#modal-close:hover{background:var(--bg-3);color:var(--text)}
.modal-body{padding:14px 18px 18px}

.mm-table{
  width:100%;border-collapse:collapse;
  background:var(--bg-2);border-radius:8px;overflow:hidden;margin-top:10px;
}
.mm-table th,.mm-table td{
  padding:8px 10px;font-size:13px;
  border-bottom:1px solid var(--line);vertical-align:middle;
}
.mm-table th{
  font-size:10px;letter-spacing:1px;text-transform:uppercase;
  color:var(--muted);background:var(--panel);font-weight:600;
}
.mm-table tr:last-child td{border-bottom:none}
.mm-table select{
  background:var(--panel);border:1px solid var(--line);border-radius:5px;
  padding:3px 5px;color:var(--text);font-size:12px;
}
.mm-invite{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap}
.mm-invite input, .mm-invite select{
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  padding:6px 8px;color:var(--text);font-size:13px;font-family:inherit;
}
.mm-invite input[type=email]{flex:1;min-width:180px}

/* ─── Sidebar drawer backdrop (mobile only) ─────────────── */
.sidebar-backdrop{display:none}

/* ─── Hide back-to-list button on desktop ──────────────── */
#btn-back-list{display:none}

/* ═══ Responsive: tablet ≤1080px ══════════════════════════ */
@media (max-width: 1080px){
  body.app{grid-template-columns:240px 1fr}
  .cols{grid-template-columns:300px 1fr}
  .note-title{font-size:22px}
}

/* ═══ Responsive: mobile ≤900px ═══════════════════════════ */
@media (max-width: 900px){
  /* Sidebar becomes a slide-in drawer */
  body.app{grid-template-columns:1fr}
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;z-index:40;
    width:80vw;max-width:300px;
    transform:translateX(-100%);
    transition:transform .25s ease;
    box-shadow:6px 0 24px rgba(40,32,18,.18);
  }
  body.nav-open .sidebar{transform:translateX(0)}

  .sidebar-backdrop{
    display:block;position:fixed;inset:0;z-index:30;
    background:rgba(40,32,18,.4);
    opacity:0;pointer-events:none;
    transition:opacity .25s ease;
  }
  body.nav-open .sidebar-backdrop{opacity:1;pointer-events:auto}

  .btn-menu{display:inline-flex}
  /* Hide search on the smallest screens — Notes/Edit page chooses it */
  .topbar input[type=search]{font-size:14px;flex:1 1 auto;min-width:0}

  /* Single-column main: list OR editor */
  .cols{grid-template-columns:1fr;grid-auto-rows:1fr;height:100%;overflow:hidden}
  .note-list-wrap{
    border-right:none;border-bottom:1px solid var(--line);
    overflow-y:auto;min-height:0;
  }
  .editor-wrap{display:none;overflow:hidden}

  /* When an editor is open, hide the list and show only the editor */
  body.show-editor .note-list-wrap{display:none}
  body.show-editor .editor-wrap{display:grid}
  body.show-editor #btn-back-list{
    display:inline-flex;
    background:transparent;border:1px solid var(--line);border-radius:6px;
    color:var(--text);width:34px;height:32px;font-size:18px;line-height:1;
    align-items:center;justify-content:center;
  }
  body.show-editor #btn-back-list:hover{background:var(--panel);border-color:var(--acc);color:var(--acc)}
  body.show-editor #btn-menu{display:none}

  .note-title{font-size:20px;padding-top:4px}
  .note-meta{padding-bottom:6px}
  .meta-field{min-width:120px;max-width:none}
  .period-row{font-size:12px}
  .ql-editor{padding:14px 16px;font-size:14px}

  .admin-bar{flex-wrap:wrap;gap:8px;padding:10px 12px}
  .admin-nav{order:3;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .admin-nav a{flex-shrink:0}
  .admin-main{padding:14px}

  .auth-card{padding:24px 20px}
  .set-grid{grid-template-columns:1fr}
}

/* ═══ Very small ≤520px ═══════════════════════════════════ */
@media (max-width: 520px){
  .topbar-status{display:none}
  .btn-save-label{display:none}      /* keep just the 💾 on tiny screens */
  .btn-save{padding:5px 8px}
  .note-meta{padding:4px 14px 8px}
  .note-title{padding:2px 14px 0;font-size:18px}
  .ql-editor{padding:12px 14px;font-size:14px}
  .modal-panel{width:96vw;max-height:92vh}
  .modal-body{padding:10px 12px 14px}
}
