/* teams.css — styles iaxion Teams */

:root{
  --bg:#0b0b14;
  --surface:#13131f;
  --surface-2:#1a1a2a;
  --surface-3:#22223a;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --ink:#ecebf5;
  --ink-dim:#b8b6cf;
  --faint:#7a779a;
  --indigo:#6366f1;
  --indigo-2:#818cf8;
  --coral:#f472b6;
  --green:#34d399;
  --amber:#fbbf24;
  --red:#f87171;
  --display:'Syne',ui-sans-serif,system-ui,sans-serif;
  --sans:'Inter',ui-sans-serif,system-ui,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
  --sidebar:268px;
  --radius:14px;
  --radius-sm:10px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
/* ── Thème Light (Kraft chaud) ───────────────────────────── */
[data-theme='light']{
  --bg:#EDE0C8;
  --surface:#F5ECD7;
  --surface-2:#EAD9C0;
  --surface-3:#DFC9A8;
  --line:rgba(196,112,58,.18);
  --line-2:rgba(196,112,58,.3);
  --ink:#3D2005;
  --ink-dim:#6B3A10;
  --faint:#8C5C30;
  --indigo:#C4703A;
  --indigo-2:#D4845A;
  --coral:#A84830;
  --green:#4A8C4A;
  --red:#C0392B;
  color-scheme:light;
}
[data-theme='light'] body{background:var(--bg);}
[data-theme='light'] .sidebar{background:var(--surface);border-color:var(--line);}
[data-theme='light'] .sidebar-head{border-color:var(--line);}
[data-theme='light'] .topbar{background:rgba(245,236,215,.9);border-color:var(--line);backdrop-filter:blur(8px);}
[data-theme='light'] .tabs{border-color:var(--line);}
[data-theme='light'] .tab-btn{color:#A07848;opacity:1;background:transparent;}
[data-theme='light'] .tab-btn:hover{color:#6B3A10;opacity:1;}
[data-theme='light'] .tab-btn.active{color:#fff!important;opacity:1!important;background:var(--indigo)!important;border-bottom-color:var(--indigo);}
[data-theme='light'] .main{background:var(--bg);}
[data-theme='light'] .tab-panel{background:var(--bg);}
[data-theme='light'] .modal-overlay .modal-box{background:var(--surface);border-color:var(--line-2);}
[data-theme='light'] input,[data-theme='light'] textarea,[data-theme='light'] select{
  background:#fff;border-color:var(--line-2);color:var(--ink);}
[data-theme='light'] input::placeholder,[data-theme='light'] textarea::placeholder{
  color:var(--faint);}
[data-theme='light'] input[type='date']{
  background:#fff;color-scheme:light;color:var(--ink);}
[data-theme='light'] .note-card{background:var(--surface);border-color:var(--line-2);}
[data-theme='light'] .note-card:hover{border-color:var(--indigo);}
[data-theme='light'] .note-title-inp{color:var(--ink);background:transparent;}
[data-theme='light'] .note-body{color:var(--ink);background:transparent;}
[data-theme='light'] .note-footer{border-color:var(--line);color:var(--faint);}
[data-theme='light'] .note-date-row{border-color:var(--line);}
[data-theme='light'] .note-date-inp{color:var(--faint)!important;background:var(--surface)!important;border:1px solid var(--line)!important;color-scheme:light;border-radius:6px!important;padding:2px 6px!important;}
[data-theme='light'] .note-date-badge{background:rgba(196,112,58,.15);color:var(--indigo);}
[data-theme='light'] .todo-add-row input{background:var(--surface);border-color:var(--line-2);}
[data-theme='light'] .todo-item{background:var(--surface);border-color:var(--line);}
[data-theme='light'] .todo-text-inp{color:var(--ink);}
[data-theme='light'] .todo-prio-sel{background:var(--surface);border:1px solid var(--line-2);color:var(--ink);}
[data-theme='light'] .todo-prio-sel.normal{background:var(--surface);color:var(--faint);}
[data-theme='light'] .todo-due-inp{background:var(--surface)!important;border:1px solid var(--line-2)!important;color-scheme:light;color:var(--faint)!important;-webkit-text-fill-color:var(--faint)!important;border-radius:8px!important;padding:4px 8px!important;}
[data-theme='light'] .todo-prio-sel.high{background:rgba(192,57,43,.1);}
[data-theme='light'] .todo-prio-sel.low{background:rgba(74,140,74,.1);}
[data-theme='light'] .file-item{background:var(--surface);border-color:var(--line);}
[data-theme='light'] .file-drop{background:var(--surface-2);border-color:var(--line-2);}
[data-theme='light'] .cal-grid{background:var(--surface);}
[data-theme='light'] .cal-cell{border-color:var(--line);background:var(--surface);}
[data-theme='light'] .cal-cell:hover{background:var(--surface-2);}
[data-theme='light'] .cal-cell.today{background:rgba(196,112,58,.12);border-color:var(--indigo);}
[data-theme='light'] .cal-cell.selected{background:rgba(196,112,58,.18);}
[data-theme='light'] .cal-side{background:var(--surface);border-color:var(--line);}
[data-theme='light'] .cal-legend{border-color:var(--line);}
[data-theme='light'] .cal-filter{border-color:var(--line-2);color:var(--faint);}
[data-theme='light'] .space-btn{color:var(--ink-dim);}
[data-theme='light'] .space-btn:hover{background:rgba(196,112,58,.08);}
[data-theme='light'] .space-btn.active{background:linear-gradient(90deg,rgba(196,112,58,.18),transparent 80%);border-left-color:var(--indigo);color:var(--ink);}
[data-theme='light'] .foot-btn{color:var(--ink-dim);border-color:var(--line-2);background:var(--surface-2);}
[data-theme='light'] .foot-btn:hover{color:#fff;border-color:var(--indigo);background:var(--indigo);}
[data-theme='light'] .sidebar-section{color:var(--faint);}
[data-theme='light'] .sidebar-foot{border-color:var(--line);}
[data-theme='light'] #pwd-modal .pwd-box{background:var(--surface);border-color:var(--line-2);}
[data-theme='light'] #pwd-modal .pwd-field input{background:#fff;}
[data-theme='light'] .demo-toast{background:var(--indigo);color:#fff;}

html,body{height:100%;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;}
body{background:
  radial-gradient(1200px 600px at 10% -10%, rgba(99,102,241,.15), transparent 60%),
  radial-gradient(900px 500px at 110% 10%, rgba(244,114,182,.10), transparent 55%),
  var(--bg);}
button,input,select,textarea{font:inherit;color:inherit;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--indigo);color:#fff;}

/* ── LAYOUT ── */
.layout{display:flex;height:100vh;overflow:hidden;}

/* ── SIDEBAR ── */
.sidebar{
  width:var(--sidebar);background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;
}
.sidebar-head{padding:1.25rem 1.1rem 1rem;border-bottom:1px solid var(--line);}
.brand{display:flex;align-items:center;gap:.55rem;}
.brand-mark{
  width:30px;height:30px;border-radius:9px;
  background:linear-gradient(135deg,var(--indigo) 0%,var(--coral) 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:800;font-size:.95rem;color:#fff;
  box-shadow:0 6px 18px -6px rgba(99,102,241,.6);
}
.brand-name{font-family:var(--display);font-weight:700;font-size:1.05rem;letter-spacing:-.02em;}
.brand-name em{font-style:normal;background:linear-gradient(135deg,var(--indigo-2),var(--coral));-webkit-background-clip:text;background-clip:text;color:transparent;}
.brand-sub{font-family:var(--mono);font-size:.62rem;color:var(--faint);text-transform:uppercase;letter-spacing:.1em;margin-top:.5rem;}
.sidebar-user{font-family:var(--mono);font-size:.68rem;color:var(--ink-dim);margin-top:.35rem;}
.sidebar-user::before{content:'@';color:var(--coral);}

.sidebar-section{
  display:flex;align-items:center;justify-content:space-between;
  padding:.95rem .95rem .35rem;font-family:var(--mono);font-size:.6rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--faint);
}
.sidebar-section .add-mini{
  background:none;border:1px solid var(--line);border-radius:6px;color:var(--ink-dim);
  padding:1px 7px;font-family:var(--mono);font-size:.7rem;cursor:pointer;transition:all .15s;line-height:1.4;
}
.sidebar-section .add-mini:hover{border-color:var(--indigo);color:#fff;background:rgba(99,102,241,.15);}
.space-btn{
  display:flex;align-items:center;gap:.6rem;padding:.55rem .95rem;
  font-family:var(--sans);font-size:.85rem;color:var(--ink-dim);cursor:pointer;
  border:none;background:none;width:100%;text-align:left;
  border-left:2px solid transparent;transition:all .18s;position:relative;
}
.space-btn:hover{background:rgba(255,255,255,.03);color:#fff;}
.space-btn.active{background:linear-gradient(90deg,rgba(99,102,241,.18),transparent 80%);border-left-color:var(--indigo);color:#fff;}
.space-btn .sp-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;background:var(--faint);}
.space-btn .sp-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.space-btn .sp-badge{font-family:var(--mono);font-size:.55rem;letter-spacing:.06em;color:var(--coral);padding:1px 5px;border:1px solid rgba(244,114,182,.3);border-radius:4px;flex-shrink:0;}
.space-btn .cog{opacity:0;background:none;border:none;color:var(--faint);font-size:.85rem;cursor:pointer;padding:0 .15rem;transition:all .15s;flex-shrink:0;}
.space-btn:hover .cog{opacity:1;}
.space-btn .cog:hover{color:#fff;}

.sidebar-foot{margin-top:auto;padding:.85rem;border-top:1px solid var(--line);display:flex;gap:.5rem;}
.foot-btn{
  flex:1;font-family:var(--mono);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.5rem .5rem;background:rgba(255,255,255,.02);border:1px solid var(--line);
  border-radius:8px;color:var(--ink-dim);cursor:pointer;text-align:center;transition:all .18s;
}
.foot-btn:hover{color:#fff;border-color:var(--indigo);background:rgba(99,102,241,.12);}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}
.topbar{
  display:flex;align-items:center;gap:1rem;padding:.95rem 1.5rem;
  border-bottom:1px solid var(--line);flex-shrink:0;background:rgba(19,19,31,.7);backdrop-filter:blur(8px);
}
.topbar-title{font-family:var(--display);font-size:1.15rem;font-weight:600;letter-spacing:-.02em;flex:1;display:flex;align-items:center;gap:.5rem;}
.topbar-title .sp-icon{font-size:1.1rem;}
.topbar-meta{font-family:var(--mono);font-size:.62rem;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;padding:2px 8px;border:1px solid var(--line);border-radius:5px;}
.topbar-meta.shared{color:var(--coral);border-color:rgba(244,114,182,.35);}
#save-status{font-family:var(--mono);font-size:.7rem;color:var(--faint);transition:color .3s;white-space:nowrap;}
#save-status.saved{color:var(--green);}
#save-status.saving{color:var(--amber);}
#save-status.error{color:var(--red);}

/* ── TABS ── */
.tabs{display:flex;gap:.25rem;padding:.5rem 1.5rem 0;border-bottom:1px solid var(--line);flex-shrink:0;background:var(--surface);}
.tab-btn{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.65rem 1rem;background:none;border:none;cursor:pointer;color:var(--faint);
  border-bottom:2px solid transparent;transition:all .18s;margin-bottom:-1px;
}
.tab-btn:hover{color:var(--ink);}
.tab-btn.active{color:#fff;border-bottom-color:var(--indigo);}
.tab-panel{display:none;flex:1;overflow-y:auto;padding:1.5rem;}
.tab-panel.active{display:block;}

/* ── CALENDRIER ── */
.cal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap;}
.cal-title{font-family:var(--display);font-size:1.6rem;font-weight:600;letter-spacing:-.02em;}
.cal-title em{font-style:normal;background:linear-gradient(135deg,var(--indigo-2),var(--coral));-webkit-background-clip:text;background-clip:text;color:transparent;}
.cal-nav{display:flex;align-items:center;gap:.4rem;}
.cal-nav button{
  padding:.45rem .75rem;background:var(--surface-2);border:1px solid var(--line);
  border-radius:8px;color:var(--ink-dim);cursor:pointer;font-family:var(--mono);font-size:.75rem;transition:all .18s;
}
.cal-nav button:hover{color:#fff;border-color:var(--indigo);background:rgba(99,102,241,.15);}
#cal-month-lbl{font-family:var(--display);font-weight:600;font-size:1rem;min-width:160px;text-align:center;}

.cal-wrap{display:grid;grid-template-columns:1fr 320px;gap:1.25rem;align-items:start;}
.cal-grid-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.3rem;margin-bottom:.4rem;}
.cal-weekday{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);text-align:center;padding:.3rem 0;}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.3rem;}
.cal-cell{
  aspect-ratio:1/1;min-height:62px;background:var(--surface-2);border:1px solid transparent;border-radius:10px;
  padding:.4rem;display:flex;flex-direction:column;cursor:pointer;transition:all .15s;position:relative;
}
.cal-cell:hover{border-color:var(--line-2);background:var(--surface-3);}
.cal-cell.other{opacity:.35;}
.cal-cell.today{border-color:var(--indigo);background:rgba(99,102,241,.10);}
.cal-cell.selected{background:linear-gradient(135deg,rgba(99,102,241,.25),rgba(244,114,182,.18));border-color:var(--indigo);}
.cal-daynum{font-family:var(--mono);font-size:.78rem;font-weight:500;color:var(--ink);}
.cal-cell.today .cal-daynum{color:var(--indigo-2);font-weight:600;}
.cal-dots{display:flex;flex-wrap:wrap;gap:3px;margin-top:auto;}
.cal-dot{width:6px;height:6px;border-radius:50%;}
.cal-count{font-family:var(--mono);font-size:.55rem;color:var(--faint);margin-top:auto;}

.cal-side{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;position:sticky;top:0;max-height:75vh;overflow-y:auto;}
.cal-side-title{font-family:var(--display);font-size:1rem;font-weight:600;margin-bottom:.8rem;padding-bottom:.6rem;border-bottom:1px solid var(--line);}
.cal-side-empty{font-family:var(--sans);font-size:.85rem;color:var(--faint);font-style:italic;padding:1rem 0;text-align:center;}
.cal-item{padding:.7rem .8rem;background:var(--surface-2);border-left:3px solid var(--indigo);border-radius:8px;margin-bottom:.55rem;transition:background .15s;}
.cal-item:hover{background:var(--surface-3);}
.cal-item-meta{display:flex;align-items:center;gap:.4rem;font-family:var(--mono);font-size:.6rem;color:var(--faint);margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.08em;}
.cal-item-space{padding:1px 6px;border-radius:4px;background:rgba(255,255,255,.06);}
.cal-item-type{color:var(--coral);}
.cal-item-type.todo{color:var(--indigo-2);}
.cal-item-title{font-family:var(--sans);font-size:.88rem;font-weight:500;color:var(--ink);line-height:1.35;}
.cal-item-body{font-family:var(--sans);font-size:.78rem;color:var(--ink-dim);margin-top:.25rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.cal-item.done{opacity:.55;}
.cal-item.done .cal-item-title{text-decoration:line-through;}
.cal-legend{margin-top:.8rem;padding-top:.7rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;}
.cal-legend-lbl{font-family:var(--mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin-right:.2rem;}
.cal-filter{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mono);font-size:.62rem;color:var(--faint);padding:3px 8px;border-radius:20px;border:1px solid var(--line);cursor:pointer;transition:all .15s;user-select:none;background:transparent;}
.cal-filter:hover{border-color:var(--line-2);color:var(--ink-dim);}
.cal-filter.active{color:var(--ink);border-color:transparent;}
.cal-filter .ld{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.cal-filter.active .ld{box-shadow:0 0 0 2px rgba(255,255,255,.15);}
.cal-filter-all{font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);background:none;border:none;cursor:pointer;padding:3px 6px;transition:color .15s;}
.cal-filter-all:hover{color:var(--ink-dim);}

/* ── NOTES ── */
.section-toolbar{display:flex;gap:.6rem;margin-bottom:1.25rem;flex-wrap:wrap;}
.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;align-items:start;}
.note-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;animation:up .25s ease;transition:transform .15s,box-shadow .2s,border-color .15s,opacity .15s;}
.note-card:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(0,0,0,.5);}
.note-card.pinned{border-color:rgba(244,114,182,.45);}
.note-card.dragging{opacity:.3;transform:scale(.97);}
.note-card.drag-over{box-shadow:0 0 0 2px var(--indigo);}
.note-titlebar{display:flex;align-items:center;padding:.65rem .8rem;border-bottom:1px solid var(--line);gap:.45rem;}
.drag-handle{flex-shrink:0;cursor:grab;color:var(--faint);font-size:.9rem;padding:0 .15rem;touch-action:none;user-select:none;line-height:1;transition:color .2s;}
.drag-handle:hover{color:var(--ink);}
.note-pin{background:none;border:none;cursor:pointer;font-size:.95rem;flex-shrink:0;opacity:.4;transition:opacity .2s;padding:0;}
.note-pin:hover,.note-pin.on{opacity:1;}
.note-title-inp{flex:1;border:none;background:transparent;font-family:var(--mono);font-size:.73rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--coral);outline:none;min-width:0;}
.note-title-inp::placeholder{color:var(--faint);}
.note-del{background:none;border:none;cursor:pointer;color:var(--faint);font-size:1rem;padding:0 .15rem;flex-shrink:0;transition:color .2s;}
.note-del:hover{color:var(--red);}
.note-body{width:100%;padding:.8rem;border:none;background:transparent;font-family:var(--sans);font-size:.92rem;line-height:1.6;color:var(--ink);resize:none;outline:none;min-height:80px;overflow:hidden;display:block;}
.note-body::placeholder{color:var(--faint);font-style:italic;}
.note-footer{padding:.4rem .8rem;border-top:1px solid var(--line);font-family:var(--mono);font-size:.62rem;color:var(--faint);display:flex;justify-content:space-between;gap:.5rem;}
.note-date-row{display:flex;align-items:center;gap:.4rem;padding:.3rem .8rem;border-top:1px solid var(--line);}
.note-date-lbl{font-family:var(--mono);font-size:.68rem;color:var(--faint);white-space:nowrap;}
.note-date-inp{font-family:var(--mono);font-size:.72rem;background:transparent;border:none;border-bottom:1px solid var(--line-2);color:var(--ink);outline:none;padding:1px 4px;border-radius:3px;cursor:pointer;}
.note-date-inp::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer;}
.note-date-inp:hover{border-bottom-color:var(--indigo);}
.note-date-badge{font-family:var(--mono);font-size:.68rem;background:rgba(99,102,241,.15);color:var(--indigo);border-radius:4px;padding:1px 6px;}
.note-author{color:var(--coral);}

/* ── TODO ── */
.todo-add-row{display:flex;gap:.6rem;margin-bottom:.6rem;flex-wrap:wrap;}
.todo-inp{flex:1;min-width:160px;padding:.65rem .85rem;background:var(--surface);border:1px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:.92rem;color:var(--ink);outline:none;transition:border-color .2s;}
.todo-inp:focus{border-color:var(--indigo);}
.todo-inp::placeholder{color:var(--faint);font-style:italic;}
.todo-meta-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem;align-items:center;}
select.todo-prio,input.todo-due{padding:.5rem .7rem;background:var(--surface);border:1px solid var(--line);border-radius:8px;font-family:var(--mono);font-size:.72rem;color:var(--ink);outline:none;}
select.todo-prio:focus,input.todo-due:focus{border-color:var(--indigo);}
input.todo-due{color-scheme:dark;}
.btn-add{padding:.6rem 1.2rem;background:linear-gradient(135deg,var(--indigo),var(--coral));color:#fff;border:none;border-radius:10px;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:transform .15s,box-shadow .2s;font-weight:500;}
.btn-add:hover{transform:translateY(-1px);box-shadow:0 10px 24px -10px rgba(99,102,241,.55);}
.todo-section-lbl{font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin:1.1rem 0 .5rem;padding-bottom:.3rem;border-bottom:1px solid var(--line);}
.todo-list{display:flex;flex-direction:column;gap:.4rem;}
.todo-item{display:flex;align-items:flex-start;gap:.7rem;padding:.65rem .85rem;background:var(--surface);border:1px solid var(--line);border-radius:10px;transition:opacity .2s,border-color .2s;animation:up .2s ease;}
.todo-item:hover{border-color:var(--line-2);}
.todo-item.done{opacity:.55;}
.todo-cb{width:16px;height:16px;flex-shrink:0;margin-top:3px;accent-color:var(--indigo);cursor:pointer;}
.todo-text-inp{flex:1;font-family:var(--sans);font-size:.92rem;line-height:1.5;color:var(--ink)!important;background:transparent!important;border:none;outline:none;resize:none;padding:0;min-height:1.4em;}
:root .todo-text-inp{-webkit-text-fill-color:#ecebf5;}
[data-theme='light'] .todo-text-inp{-webkit-text-fill-color:#3D2005!important;color:#3D2005!important;}
.todo-item.done .todo-text-inp{text-decoration:line-through;color:var(--faint);}
[data-theme='light'] .todo-item.done .todo-text-inp{-webkit-text-fill-color:var(--faint)!important;}
.todo-badge{font-family:var(--mono);font-size:.58rem;padding:.18rem .42rem;border-radius:5px;flex-shrink:0;white-space:nowrap;margin-top:3px;letter-spacing:.04em;}
.todo-badge.high{background:rgba(248,113,113,.16);color:var(--red);}
.todo-badge.normal{display:none;}
.todo-badge.low{background:rgba(52,211,153,.16);color:var(--green);}
.todo-due-lbl{font-family:var(--mono);font-size:.62rem;color:var(--faint);flex-shrink:0;margin-top:3px;white-space:nowrap;}
.todo-due-lbl.overdue{color:var(--red);}
.todo-due-inp{font-family:var(--mono);font-size:.62rem;color:var(--faint);flex-shrink:0;margin-top:2px;background:transparent;border:none;border-bottom:1px solid var(--line-2);outline:none;padding:0 2px;cursor:pointer;color-scheme:dark;width:110px;}
.todo-due-inp.overdue{color:var(--red);}
.todo-due-inp:focus{border-bottom-color:var(--indigo);color:var(--ink);}
.todo-prio-sel{font-family:var(--mono);font-size:.58rem;padding:.15rem .35rem;border-radius:5px;flex-shrink:0;margin-top:3px;border:none;cursor:pointer;outline:none;background:transparent;}
.todo-prio-sel.high{background:rgba(248,113,113,.16);color:var(--red);}
.todo-prio-sel.normal{background:rgba(255,255,255,.06);color:var(--faint);}
.todo-prio-sel.low{background:rgba(52,211,153,.16);color:var(--green);}
.todo-author{font-family:var(--mono);font-size:.6rem;color:var(--coral);margin-top:3px;flex-shrink:0;}
.todo-del-btn{background:none;border:none;cursor:pointer;color:var(--faint);font-size:.9rem;flex-shrink:0;transition:color .2s;padding:0;margin-top:1px;}
.todo-del-btn:hover{color:var(--red);}
.btn-clear{margin-top:.8rem;font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);background:none;border:1px dashed var(--line-2);border-radius:8px;padding:.4rem .8rem;cursor:pointer;transition:all .2s;}
.btn-clear:hover{color:var(--red);border-color:var(--red);border-style:solid;}

/* ── FILES ── */
.drop-zone{border:2px dashed var(--line-2);border-radius:var(--radius);padding:2rem 1.5rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:1.5rem;user-select:none;background:var(--surface);}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--indigo);background:rgba(99,102,241,.06);}
.drop-zone p{font-family:var(--sans);font-size:.85rem;color:var(--ink-dim);}
.drop-zone p strong{color:var(--coral);font-weight:600;}
.drop-zone input[type=file]{display:none;}
.drop-icon{font-size:2rem;margin-bottom:.5rem;display:block;background:linear-gradient(135deg,var(--indigo-2),var(--coral));-webkit-background-clip:text;background-clip:text;color:transparent;}
.upload-bar-wrap{display:none;margin-bottom:1.25rem;}
.upload-bar-wrap.visible{display:block;}
.upload-bar-bg{background:var(--surface-3);border-radius:99px;height:4px;overflow:hidden;}
.upload-bar-fill{background:linear-gradient(90deg,var(--indigo),var(--coral));height:4px;width:0%;transition:width .2s;}
.upload-lbl{font-family:var(--mono);font-size:.7rem;color:var(--ink-dim);margin-bottom:.35rem;}
.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.9rem;}
.file-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;animation:up .25s ease;transition:border-color .2s,transform .15s;}
.file-card:hover{border-color:var(--line-2);transform:translateY(-2px);}
.file-thumb{width:100%;height:110px;object-fit:cover;display:block;cursor:zoom-in;}
.file-icon-wrap{width:100%;height:110px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);cursor:pointer;}
.file-icon{font-size:2.2rem;}
.file-info{padding:.5rem .6rem;border-top:1px solid var(--line);}
.file-name{font-family:var(--mono);font-size:.66rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.2rem;}
.file-meta{font-family:var(--mono);font-size:.58rem;color:var(--faint);}
.file-author{font-family:var(--mono);font-size:.58rem;color:var(--coral);margin-bottom:.15rem;}
.file-acts{display:flex;gap:.35rem;margin-top:.4rem;}
.file-dl,.file-del-btn{font-family:var(--mono);font-size:.58rem;letter-spacing:.05em;text-transform:uppercase;padding:.22rem .45rem;border:1px solid var(--line);border-radius:5px;background:transparent;color:var(--ink-dim);cursor:pointer;transition:all .15s;}
.file-dl:hover{color:var(--green);border-color:var(--green);}
.file-del-btn:hover{color:var(--red);border-color:var(--red);}

/* ── LIGHTBOX ── */
.lightbox{display:none;position:fixed;inset:0;background:rgba(11,11,20,.95);z-index:2000;align-items:center;justify-content:center;padding:1rem;cursor:zoom-out;backdrop-filter:blur(6px);}
.lightbox.open{display:flex;}
.lightbox img{max-width:100%;max-height:90vh;border-radius:8px;box-shadow:0 16px 60px rgba(0,0,0,.7);cursor:default;}
.lightbox-close{position:fixed;top:1.2rem;right:1.5rem;background:none;border:none;color:#fff;font-size:1.8rem;cursor:pointer;z-index:2001;}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(11,11,20,.7);z-index:1500;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto;backdrop-filter:blur(4px);}
.modal-bg.open{display:flex;}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:1.6rem;width:100%;max-width:480px;margin:auto;animation:up .25s ease;box-shadow:0 30px 80px -30px rgba(0,0,0,.6);}
.modal h3{font-family:var(--display);font-size:1.1rem;font-weight:600;margin-bottom:1.1rem;padding-bottom:.6rem;border-bottom:1px solid var(--line);}
.form-group{margin-bottom:.9rem;}
.form-group label{display:block;font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:.3rem;}
.form-group input[type=text],.form-group input[type=password]{width:100%;padding:.6rem .8rem;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;font-family:var(--sans);font-size:.92rem;color:var(--ink);outline:none;transition:border-color .2s;}
.form-group input:focus{border-color:var(--indigo);}
.color-row{display:flex;align-items:center;gap:.7rem;}
.color-row input[type=color]{width:42px;height:36px;border:1px solid var(--line);border-radius:8px;cursor:pointer;padding:2px;background:none;}
.color-row span{font-family:var(--mono);font-size:.78rem;color:var(--faint);}
.shares-selector{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.3rem;}
.share-toggle{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--mono);font-size:.7rem;padding:.3rem .65rem;border:1px solid var(--line);border-radius:8px;cursor:pointer;background:var(--surface-2);color:var(--ink-dim);transition:all .15s;}
.share-toggle:hover{border-color:var(--line-2);color:#fff;}
.share-toggle.on{background:linear-gradient(135deg,var(--indigo),var(--coral));color:#fff;border-color:transparent;}
.modal-footer{display:flex;gap:.5rem;justify-content:space-between;align-items:center;margin-top:1.3rem;padding-top:.85rem;border-top:1px solid var(--line);}
.modal-footer .left,.modal-footer .right{display:flex;gap:.5rem;}
.btn-ghost{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;padding:.5rem .9rem;background:none;border:1px solid var(--line);border-radius:8px;color:var(--ink-dim);cursor:pointer;transition:all .15s;}
.btn-ghost:hover{color:#fff;border-color:var(--indigo);background:rgba(99,102,241,.1);}
.btn-danger{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;padding:.5rem .9rem;background:none;border:1px solid rgba(248,113,113,.4);border-radius:8px;color:var(--red);cursor:pointer;transition:all .15s;}
.btn-danger:hover{background:var(--red);color:#fff;border-color:var(--red);}
.btn-primary{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;padding:.5rem 1.1rem;background:linear-gradient(135deg,var(--indigo),var(--coral));border:none;border-radius:8px;color:#fff;cursor:pointer;transition:transform .15s,box-shadow .2s;font-weight:500;}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 22px -10px rgba(99,102,241,.55);}

/* ── MISC ── */
.btn-sm{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:var(--surface);border:1px solid var(--line-2);border-radius:10px;font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;color:var(--ink-dim);cursor:pointer;transition:all .18s;}
.btn-sm:hover{color:#fff;border-color:var(--indigo);background:rgba(99,102,241,.12);}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--faint);font-style:italic;font-size:.92rem;}
@keyframes up{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ── MOBILE ── */
.menu-toggle{display:none;background:none;border:none;font-size:1.3rem;cursor:pointer;padding:.2rem;color:var(--ink);}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;}
@media(max-width:900px){
  .cal-wrap{grid-template-columns:1fr;}
  .cal-side{position:static;max-height:none;}
}
@media(max-width:680px){
  .sidebar{position:fixed;left:-100%;top:0;height:100%;z-index:100;transition:left .25s;}
  .sidebar.open{left:0;}
  .sidebar-overlay.open{display:block;}
  .menu-toggle{display:block;}
  .tab-panel{padding:1rem;}
  .notes-grid{grid-template-columns:1fr;}
  .files-grid{grid-template-columns:repeat(2,1fr);}
  .cal-cell{min-height:48px;padding:.3rem;}
  .topbar{padding:.75rem 1rem;}
  .tabs{padding:.4rem .75rem 0;overflow-x:auto;}
}
#pwd-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:300;align-items:center;justify-content:center;padding:1rem;}
#pwd-modal.open{display:flex;}
.pwd-box{background:var(--surface);border:1px solid var(--line-2);border-radius:16px;padding:1.8rem 1.6rem;width:100%;max-width:360px;display:flex;flex-direction:column;gap:1rem;}
.pwd-box h3{font-family:var(--display);font-size:1rem;font-weight:600;}
.pwd-field{display:flex;flex-direction:column;gap:.3rem;}
.pwd-field label{font-family:var(--mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--faint);}
.pwd-field input{padding:.6rem .8rem;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;font-family:var(--sans);font-size:.92rem;color:var(--ink);outline:none;}
.pwd-field input:focus{border-color:var(--indigo);}
.pwd-row{display:flex;gap:.6rem;justify-content:flex-end;}
.pwd-msg{font-family:var(--mono);font-size:.7rem;min-height:1.2em;}
.pwd-msg.ok{color:#4ade80;} .pwd-msg.err{color:var(--red);}

[data-theme='light'] .cat-input,[data-theme='light'] .cat-select{background:#fff!important;}
[data-theme='light'] .form-group input,[data-theme='light'] .form-group select{background:#fff;}

[data-theme='light'] .note-date-inp::-webkit-calendar-picker-indicator{filter:invert(.3) sepia(.5) saturate(2) hue-rotate(330deg);}

[data-theme='light'] .note-date-badge{display:none;}

/* ── Admin light ─────────────────────────────────────────── */
[data-theme='light'] .wrap{background:var(--bg);}
[data-theme='light'] .page-header{background:var(--surface);border-color:var(--line);}
[data-theme='light'] .brand-name{color:var(--ink);}
[data-theme='light'] .brand-sub{color:var(--faint);}
[data-theme='light'] .brand-mark{background:var(--indigo);}
[data-theme='light'] .card{background:var(--surface);border-color:var(--line-2);}
[data-theme='light'] .card-title{color:var(--ink);border-color:var(--line);}
[data-theme='light'] .tbl th{color:var(--faint);border-color:var(--line);}
[data-theme='light'] .tbl td{color:var(--ink);border-color:var(--line);}
[data-theme='light'] .tbl tr:hover{background:var(--surface-2);}
[data-theme='light'] .btn-sm{background:var(--surface-2);border-color:var(--line-2);color:var(--ink);}
[data-theme='light'] .btn-sm:hover{border-color:var(--indigo);color:var(--indigo);}
[data-theme='light'] .btn-danger{background:rgba(192,57,43,.1);border-color:rgba(192,57,43,.3);color:var(--red);}
[data-theme='light'] .form-row label{color:var(--faint);}
[data-theme='light'] .form-row input,[data-theme='light'] .form-row select{
  background:#fff;border-color:var(--line-2);color:var(--ink);}
[data-theme='light'] .back-btn{color:var(--faint);border-color:var(--line);}

/* ── Todo date wrapper (fix iOS native white box) ───────── */
.todo-due-card-wrap{position:relative;display:inline-flex;align-items:center;}
.todo-due-label{font-family:var(--mono);font-size:.62rem;color:var(--faint);cursor:pointer;padding:2px 7px;border-radius:6px;border:1px solid var(--line-2);background:transparent;white-space:nowrap;}
.todo-due-label.overdue{color:var(--red);border-color:var(--red);}
.todo-due-wrap{position:relative;display:inline-flex;align-items:center;}
.todo-due-wrap input[type='date']{opacity:0;position:absolute;width:100%;height:100%;cursor:pointer;}
.todo-due-lbl{font-family:var(--mono);font-size:.72rem;color:var(--faint);cursor:pointer;padding:4px 10px;border-radius:8px;border:1px solid var(--line-2);background:transparent;}
[data-theme='light'] .todo-due-label{color:var(--faint);border-color:var(--line-2);background:var(--surface);}
[data-theme='light'] .todo-due-lbl{color:var(--faint);border-color:var(--line-2);background:var(--surface);}
.todo-due-inp{opacity:0;position:absolute;width:1px;height:1px;pointer-events:none;}
