/* Nichols-Dixon Family Tasks — Things-style, warm editorial tokens. */
:root{
  --cream:#FAF6EF; --paper:#FFFDF9; --sidebar:#F4EEE3; --ink:#2B2622; --muted:#8A7F72;
  --line:#E7DECF; --accent:#B5683F; --accent-soft:#F0E2D6; --olive:#6E7150;
  --danger:#A8442B; --done:#9AA17F; --a1:#B5683F; --a2:#6E7150;
  --display:'Fraunces','Hoefler Text',Georgia,serif;
  --body:'Source Serif 4',Georgia,serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--cream);color:var(--ink);font-family:var(--body);line-height:1.55;
  -webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:none}
button{font-family:var(--body)}

/* ---------- App shell ---------- */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:264px;flex:0 0 264px;background:var(--sidebar);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 12px;position:sticky;top:0;height:100vh;overflow:hidden}
.side-brand{font-family:var(--display);font-weight:600;font-size:18px;padding:6px 10px 14px;letter-spacing:-.01em}
.side-nav{display:flex;flex-direction:column;gap:1px;margin-bottom:14px}
.side-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:8px;color:var(--ink);font-size:15px}
.side-item:hover{background:rgba(43,38,34,.05)}
.side-item.active{background:var(--accent-soft)}
.si-ico{width:18px;text-align:center;color:var(--muted);font-size:13px}
.si-ico.today{color:#D9A300}
.si-count{margin-left:auto;font-size:12px;color:var(--muted);background:rgba(43,38,34,.07);border-radius:999px;padding:1px 8px}
.si-count.accent{background:var(--accent);color:#fff}
.side-scroll{flex:1;overflow-y:auto;margin:0 -4px;padding:0 4px}
.side-area{margin-bottom:14px}
.side-area-name{display:block;font-family:var(--display);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);padding:4px 10px;border-radius:6px}
.side-area-name:hover,.side-area-name.active{color:var(--accent)}
.side-proj{display:flex;align-items:center;gap:9px;padding:5px 10px;border-radius:8px;color:var(--ink);font-size:14px}
.side-proj:hover{background:rgba(43,38,34,.05)}
.side-proj.active{background:var(--accent-soft)}
.proj-dot{width:12px;height:12px;border-radius:50%;flex:0 0 12px;
  background:conic-gradient(var(--accent) calc(var(--p,0) * 1%), rgba(43,38,34,.13) 0);border:1px solid var(--line)}
.side-add{margin-top:8px;font-size:13px}
.side-add>summary{cursor:pointer;color:var(--muted);padding:6px 10px;list-style:none}
.side-add>summary::-webkit-details-marker{display:none}
.side-viewer{padding:10px 10px 6px;border-top:1px solid var(--line);margin-top:6px}
.vw-cap{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.vw-pills{display:flex;gap:6px}
.vw-pill-form{flex:1;margin:0}
.vw-pill{width:100%;font-family:var(--body);font-size:13px;padding:6px 8px;border:1px solid var(--line);
  border-radius:8px;background:var(--paper);color:var(--ink);cursor:pointer}
.vw-pill:hover{border-color:var(--accent);color:var(--accent)}
.vw-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}
.vw-pill.active:hover{color:#fff}
.mt-viewer{border-top:1px solid var(--line);margin-top:6px}
.side-signout{display:block;color:var(--muted);font-size:13px;padding:8px 10px;margin-top:4px}
.side-signout:hover{color:var(--accent)}
.mini-form{display:flex;flex-direction:column;gap:6px;padding:8px 10px}
.mini-form.stack label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted)}
.mini-form input,.mini-form select,.mini-form textarea{font-family:var(--body);font-size:14px;padding:8px 10px;
  border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink)}
.inline-new{flex-direction:row;align-items:center;padding:0;margin-top:14px}
.inline-new input{flex:1}

/* ---------- Main ---------- */
.main{flex:1;min-width:0;display:flex;justify-content:center}
.content{width:100%;max-width:720px;padding:42px 30px 80px}
.content.narrow{max-width:600px}
.view-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.view-head h1{font-family:var(--display);font-weight:500;font-size:30px;letter-spacing:-.02em}
.view-ico{font-size:20px;color:var(--muted)}
.view-ico.today{color:#D9A300}
.view-sub{color:var(--muted);font-size:15px;margin:-6px 0 18px}
.back{color:var(--muted);font-size:14px}
.head-menu{margin-left:auto;position:relative}
.head-menu>summary{cursor:pointer;color:var(--muted);list-style:none;padding:4px 8px;border-radius:6px}
.head-menu>summary::-webkit-details-marker{display:none}
.head-menu>summary:hover{background:rgba(43,38,34,.06)}
.head-menu[open]>summary{background:var(--accent-soft)}
.head-menu .menu-pop{position:absolute;right:0;top:36px;z-index:20;width:280px;background:var(--paper);
  border:1px solid var(--line);border-radius:14px;box-shadow:0 10px 30px rgba(43,38,34,.18);
  padding:14px;display:flex;flex-direction:column;gap:10px}
.head-menu .menu-pop .mini-form{padding:0}
.head-menu .menu-sep{height:1px;background:var(--line);margin:2px 0}
.menu-link{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:var(--body);font-size:14px;color:var(--ink);padding:7px 8px;border-radius:8px}
.menu-link:hover{background:var(--accent-soft)}
.menu-link.danger{color:var(--danger)}
.menu-link.danger:hover{background:#f3d9d1}

/* ---------- Quick add ---------- */
.quick-add{display:flex;gap:10px;margin:6px 0 22px}
.qa-input{flex:1;font-family:var(--body);font-size:15.5px;padding:11px 14px;border:1px solid var(--line);
  border-radius:10px;background:var(--paper);color:var(--ink)}
.qa-input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:15px;background:var(--accent);
  color:#fff;border:1px solid var(--accent);border-radius:999px;padding:10px 20px;cursor:pointer}
.btn:hover{filter:brightness(.96)}
.btn.small{padding:7px 14px;font-size:14px}
.btn.ghost{background:transparent;color:var(--accent)}
.btn.danger{background:var(--danger);border-color:var(--danger)}
.btn.danger.ghost{background:transparent;color:var(--danger)}
.icon-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:4px 7px;border-radius:7px;line-height:1}
.icon-btn:hover{color:var(--accent);background:var(--accent-soft)}
.icon-btn.danger:hover{color:var(--danger)}

/* ---------- Groups + task rows ---------- */
.group{margin-bottom:26px}
.group-h{font-family:var(--display);font-weight:500;font-size:15px;color:var(--muted);
  padding-bottom:7px;border-bottom:1px solid var(--line);margin-bottom:6px}
.group-h.overdue{color:var(--danger)}
.group-h.heading{color:var(--ink);font-size:16px}
.heading-group{margin-top:26px}
.heading-row{display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--line);margin-bottom:6px}
.heading-row .group-h{border:none;margin:0;flex:1}
ul.tasks{list-style:none}
.task{display:flex;align-items:flex-start;gap:11px;padding:9px 4px;border-bottom:1px solid rgba(231,222,207,.6)}
.task:last-child{border-bottom:none}
.check{appearance:none;-webkit-appearance:none;flex:0 0 auto;width:20px;height:20px;margin-top:1px;
  border:1.5px solid var(--muted);border-radius:6px;background:transparent;cursor:pointer;transition:all .12s}
.check:hover{border-color:var(--accent)}
.check.done{background:var(--done);border-color:var(--done)}
.check.recurring{border-radius:50%}
.task-main{flex:1;min-width:0;color:var(--ink);display:flex;flex-direction:column;gap:3px}
.task-main:hover .task-title{color:var(--accent)}
.task-title{font-size:15.5px;line-height:1.35}
.task.complete .task-title{color:var(--muted);text-decoration:line-through}
.task-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.badge{font-size:12px;padding:1px 8px;border-radius:999px;line-height:1.55;white-space:nowrap}
.badge.when{background:var(--accent-soft);color:#7a3a22}
.badge.when.over{background:#f3d9d1;color:var(--danger)}
.badge.deadline{background:#f3d9d1;color:var(--danger)}
.badge.who{background:#eef0e6;color:#55583c}
.badge.recur,.badge.note{background:transparent;border:1px solid var(--line);color:var(--muted)}
.badge.ctx{background:transparent;color:var(--muted);border:1px solid var(--line)}
.row-del{opacity:0;transition:opacity .12s}
.task:hover .row-del{opacity:.7}
.empty{color:var(--muted);font-style:italic;padding:14px 4px}
.empty.small{padding:6px 4px;font-size:14px}

/* ---------- Project cards / rings ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:24px}
.proj-card{display:flex;flex-direction:column;gap:6px;padding:16px;background:var(--paper);border:1px solid var(--line);
  border-radius:14px;box-shadow:0 1px 4px rgba(43,38,34,.05)}
.proj-card:hover{box-shadow:0 4px 14px rgba(43,38,34,.10)}
.proj-card-name{font-family:var(--display);font-size:17px;color:var(--ink)}
.proj-card-meta{font-size:13px;color:var(--muted)}
.proj-ring{display:inline-block;width:18px;height:18px;border-radius:50%;
  background:conic-gradient(var(--accent) calc(var(--p,0) * 1%), rgba(43,38,34,.13) 0);border:1px solid var(--line)}
.proj-ring.big{width:22px;height:22px}

/* ---------- Calendar ---------- */
.cal{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:28px}
.cal-head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.cal-title{font-family:var(--display);font-size:18px}
.cal-nav{font-size:20px;color:var(--muted);padding:0 6px;border-radius:6px}
.cal-nav:hover{color:var(--accent)}
.cal-today{margin-left:auto;font-size:13px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.cal-dow{background:var(--paper);text-align:center;font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:7px 0 6px}
.cal-cell{background:var(--paper);min-height:56px;padding:5px;display:flex;flex-direction:column;align-items:flex-start;gap:5px}
.cal-cell.muted{background:#faf8f2}
.cal-cell.muted .cal-num{color:#cabfae}
.cal-num{font-size:12.5px;color:var(--ink);width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;line-height:1}
.cal-cell.is-today .cal-num{background:var(--accent);color:#fff;font-weight:600}
.cal-dots{display:flex;flex-wrap:wrap;gap:4px;padding-left:3px}
.cal-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);transition:transform .1s ease}
.cal-dot:hover{transform:scale(1.45)}
.cal-dot.a1{background:var(--a1)}
.cal-dot.a2{background:var(--a2)}
.cal-more{font-size:10px;color:var(--muted);line-height:1}

/* ---------- Timeline ---------- */
.timeline .group-h{border:none}
.tl-row{display:flex;gap:16px;padding:8px 0;border-bottom:1px solid rgba(231,222,207,.6)}
.tl-date{flex:0 0 56px;text-align:center;border-radius:10px;padding:6px 0;background:var(--sidebar);height:fit-content}
.tl-day{display:block;font-family:var(--display);font-size:20px;line-height:1}
.tl-mon{display:block;font-size:11px;text-transform:uppercase;color:var(--muted)}
.tl-dow{display:block;font-size:11px;color:var(--muted)}
.tl-tasks{flex:1}

/* ---------- Forms / task editor ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 1px 6px rgba(43,38,34,.05)}
.title-input{width:100%;font-family:var(--display);font-size:22px;font-weight:500;border:none;background:transparent;color:var(--ink);margin-bottom:8px}
.title-input:focus{outline:none}
.field-input,.form-card select,.form-card textarea{width:100%;font-family:var(--body);font-size:15px;padding:9px 12px;
  border:1px solid var(--line);border-radius:9px;background:var(--cream);color:var(--ink)}
.field-input:focus,.form-card select:focus,.form-card textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}
.form-card textarea{margin-bottom:14px;resize:vertical}
.form-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:6px}
.field{flex:1 1 150px;display:flex;flex-direction:column;gap:5px}
.field>span{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.block{border:1px solid var(--line);border-radius:12px;padding:14px;margin-top:16px}
.block legend{font-family:var(--display);font-size:13px;color:var(--muted);padding:0 6px}
.narrow-num{width:90px;display:inline-block}
.mini-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-right:8px}
.rec-monthly,.rec-setpos,.rec-weekdays{margin-top:12px;display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.rec-monthly .radio{display:inline-flex;align-items:center;gap:6px;font-size:14px}
.chk{display:inline-flex;align-items:center;gap:5px;font-size:14px;background:var(--cream);border:1px solid var(--line);
  border-radius:999px;padding:5px 11px;cursor:pointer}
.rec-hint{margin-top:12px;font-size:13px;color:var(--muted)}
.form-actions{display:flex;align-items:center;gap:12px;margin-top:18px}
.form-actions .spacer{flex:1}
.danger-form{margin-top:14px;text-align:center}

/* ---------- Login (standalone) ---------- */
body.plain{display:flex;min-height:100vh}
.login-shell{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;max-width:380px;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:40px 34px;box-shadow:0 2px 10px rgba(43,38,34,.05)}
.login-card .brand{display:block;text-align:center;font-family:var(--display);font-weight:600;font-size:28px;margin-bottom:6px}
.login-card .sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:28px}
.login-card .field{margin-bottom:16px}
.login-card input{width:100%;font-family:var(--body);font-size:16px;padding:13px 15px;border:1px solid var(--line);border-radius:10px;background:var(--cream);color:var(--ink)}
.login-card input:focus{outline:2px solid var(--accent);outline-offset:2px;border-color:transparent}
.login-card .btn{width:100%}
.error{background:var(--accent-soft);color:#7a3a22;border-radius:10px;padding:10px 14px;font-size:14px;margin-bottom:16px;text-align:center}

.si-ico.log{color:var(--done)}

/* ---------- Logbook ---------- */
.logbook{list-style:none}
.log-row{padding:12px 4px;border-bottom:1px solid rgba(231,222,207,.6)}
.log-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.log-done{display:inline-flex;align-items:center;gap:5px;color:var(--done);font-size:13px;font-weight:600}
.log-status{font-size:12px;padding:1px 9px;border-radius:999px}
.log-status.ontime{background:#e3efe1;color:#3f6b46}
.log-status.late{background:#f6e7cf;color:#9a6a1c}
.log-when{margin-left:auto;color:var(--muted);font-size:13px}
.log-title{font-size:15.5px;margin:3px 0 5px}
.log-meta{display:flex;flex-wrap:wrap;gap:6px}

/* ---------- Reminders editor ---------- */
.rem-card{margin-top:16px}
.rem-head{font-family:var(--display);font-size:15px;margin-bottom:10px}
.rem-list{list-style:none;margin-bottom:12px}
.rem-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(231,222,207,.6)}
.rem-num{width:22px;height:22px;flex:0 0 22px;border-radius:50%;color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;background:var(--muted)}
.rem-num.before{background:var(--olive)}
.rem-num.due{background:#D9A300}
.rem-num.after{background:var(--danger)}
.rem-label{flex:1;font-size:15px}
.badge.kind{border:1px solid var(--line);color:var(--muted)}
.badge.kind.reminder{background:#e3efe1;color:#3f6b46;border-color:transparent}
.badge.kind.due_alert{background:#f6e7cf;color:#9a6a1c;border-color:transparent}
.badge.kind.followup{background:#f3d9d1;color:var(--danger);border-color:transparent}
.rem-del{display:flex}
.rem-add{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rem-add select,.rem-add .narrow-num{padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--cream);font-family:var(--body);font-size:14px}
.rem-unit{color:var(--muted);font-size:14px;margin-left:-4px}

/* ---------- Project emoji glyphs ---------- */
.proj-emoji-sm{width:18px;flex:0 0 18px;text-align:center;font-size:14px;line-height:1}
.proj-emoji{font-size:26px;line-height:1}
.proj-progress{font-size:13px;color:var(--muted);margin-left:auto;align-self:center}

/* ---------- Composer reveal ---------- */
.quick-add{display:block;margin:6px 0 22px}
.qa-row{display:flex;gap:10px}
.qa-extra{display:none;gap:12px;margin-top:10px;padding:10px 2px 2px}
.quick-add:focus-within .qa-extra{display:flex;flex-wrap:wrap}
.qa-field{display:flex;flex-direction:column;gap:4px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.qa-field input,.qa-field select{font-family:var(--body);font-size:14px;text-transform:none;letter-spacing:0;
  padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--cream);color:var(--ink)}

/* ---------- Expand-to-edit inline panel ---------- */
.task{flex-wrap:wrap}
.task-panel{flex-basis:100%;width:100%;margin:8px 0 4px}
.task-panel:not([hidden]){animation:slideDown .14s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.task-panel .form-card{background:var(--cream);border:1px solid var(--line)}
.task-panel .title-input{font-size:18px}
.inline-more{display:flex;align-items:center;gap:14px;margin-top:10px;padding-left:4px}
.more-link{font-size:13px;color:var(--muted);background:none;border:none;cursor:pointer;padding:0;font-family:var(--body)}
.more-link:hover{color:var(--accent)}
.more-link.danger:hover{color:var(--danger)}
.inline-del{display:inline}

/* ---------- Drag between buckets ---------- */
li.task{cursor:default}
li.task[draggable=true] .task-main{cursor:grab}
li.task.dragging{opacity:.45}
.drop-hover{outline:2px dashed var(--accent);outline-offset:1px;background:var(--accent-soft)!important;border-radius:8px}
/* In-project drop zones (headings + the no-heading area) */
.heading-group{border-radius:10px;transition:background .1s ease}
.drop-zone{border-radius:10px;min-height:8px}
.drop-empty{color:var(--muted);font-style:italic;font-size:14px;padding:10px 4px;border:1px dashed transparent;border-radius:8px}
.heading-group.drop-hover,.drop-zone.drop-hover{outline:2px dashed var(--accent);outline-offset:3px;background:var(--accent-soft)!important}
.heading-group.drop-hover .heading,.drop-zone.drop-hover .drop-empty{color:var(--accent)}
/* a clear drop line at the top of a heading while dragging over it */
.heading-group.drop-hover .heading-row{box-shadow:0 -3px 0 var(--accent)}

/* ---------- Minimized add-heading ---------- */
.add-heading{margin-top:14px}
.add-heading>summary{cursor:pointer;list-style:none;color:var(--accent);font-size:14px;display:inline-block;padding:4px 0}
.add-heading>summary::-webkit-details-marker{display:none}
.add-heading[open]>summary{color:var(--muted);margin-bottom:8px}
.add-heading .inline-new{margin-top:0}

/* ---------- Collapsed calendar ---------- */
.cal-toggle{margin-top:18px}
.cal-toggle>summary{cursor:pointer;list-style:none;color:var(--accent);font-size:14px;padding:6px 0}
.cal-toggle>summary::-webkit-details-marker{display:none}
.cal-toggle[open]>summary{color:var(--muted);margin-bottom:8px}
.cal-toggle .cal{margin-bottom:0}

/* ---------- Inbox filing ---------- */
.inbox-task .file-form{flex:0 0 auto}
.filer{position:relative;display:inline-flex;align-items:stretch}
.filer-accept{font-family:var(--body);font-size:13px;cursor:pointer;background:var(--accent-soft);color:#7a3a22;
  border:1px solid #e3c9b8;border-right:none;border-radius:999px 0 0 999px;padding:6px 12px;white-space:nowrap;
  max-width:260px;overflow:hidden;text-overflow:ellipsis}
.filer-accept:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.filer-accept .fi-sep{opacity:.6}
.filer-caret{font-family:var(--body);font-size:13px;cursor:pointer;background:var(--accent-soft);color:#7a3a22;
  border:1px solid #e3c9b8;border-radius:0 999px 999px 0;padding:6px 11px}
.filer-caret:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.filer-empty{border-radius:999px;border:1px solid var(--line);background:var(--paper);color:var(--muted);padding:6px 14px}
.filer-empty:hover{border-color:var(--accent);color:var(--accent)}
.filer-menu{position:absolute;top:calc(100% + 5px);right:0;z-index:30;min-width:236px;background:var(--paper);
  border:1px solid var(--line);border-radius:13px;box-shadow:0 12px 32px rgba(43,38,34,.18);padding:6px}
.filer-item{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;
  font-family:var(--body);font-size:14px;color:var(--ink);background:none;border:none;cursor:pointer;
  padding:8px 11px;border-radius:9px;position:relative}
.filer-item:hover{background:var(--accent-soft)}
.fi-arrow{color:var(--muted)}
.filer-sub{display:none;position:absolute;left:100%;top:-6px;margin-left:5px;min-width:196px;background:var(--paper);
  border:1px solid var(--line);border-radius:13px;box-shadow:0 12px 32px rgba(43,38,34,.18);padding:6px}
.has-sub:hover .filer-sub,.has-sub.open .filer-sub{display:block}
.filer-opt{display:block;width:100%;text-align:left;font-family:var(--body);font-size:14px;color:var(--ink);
  background:none;border:none;cursor:pointer;padding:8px 11px;border-radius:9px;white-space:nowrap}
.filer-opt:hover{background:var(--accent-soft)}
.fi-dim{color:var(--muted);font-size:12px}
@media(max-width:560px){
  .inbox-task .file-form{flex-basis:100%;margin-top:6px}
  .filer-menu{right:auto;left:0}
  .filer-sub{position:static;left:auto;margin:2px 0 2px 14px;box-shadow:none;border:none;padding:0;min-width:0}
  .has-sub:hover .filer-sub{display:none}
  .has-sub.open .filer-sub{display:block}
}

/* ---------- Mobile top nav ---------- */
.mobile-top{display:none}

@media(max-width:720px){
  .sidebar{display:none}
  .content{padding:18px 16px 60px}
  .mobile-top{display:block;position:sticky;top:0;z-index:20;background:var(--sidebar);border-bottom:1px solid var(--line)}
  .mt-bar{display:flex;align-items:center;gap:12px;padding:12px 16px 8px}
  .mt-brand{font-family:var(--display);font-weight:600;font-size:18px}
  .mt-menu{margin-left:auto;position:relative}
  .mt-menu>summary{cursor:pointer;list-style:none;color:var(--accent);font-size:14px;padding:6px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper)}
  .mt-menu>summary::-webkit-details-marker{display:none}
  .mt-drop{position:absolute;right:0;top:40px;background:var(--paper);border:1px solid var(--line);border-radius:12px;
    box-shadow:0 8px 28px rgba(43,38,34,.16);min-width:220px;max-height:70vh;overflow-y:auto;padding:8px}
  .mt-drop a{display:block;padding:9px 12px;border-radius:8px;color:var(--ink);font-size:15px}
  .mt-drop a:hover{background:var(--accent-soft)}
  .mt-area{font-family:var(--display);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)!important}
  .mt-proj{padding-left:22px!important}
  .mt-signout{border-top:1px solid var(--line);margin-top:6px;color:var(--muted)!important}
  .mt-nav{display:flex;gap:4px;padding:0 10px 8px;overflow-x:auto}
  .mt-item{flex:0 0 auto;display:flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;color:var(--ink);font-size:14px;white-space:nowrap}
  .mt-item.active{background:var(--accent);color:#fff}
  .mt-c{font-size:12px;background:rgba(43,38,34,.12);border-radius:999px;padding:0 7px}
  .mt-item.active .mt-c{background:rgba(255,255,255,.25)}
}
