/* ============================================================
   SIFLA — style.css  (faithful to mockup)
   Inter font · #7c5cbf purple accent · Trello-like board
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800;900&display=swap');

:root {
  --bg-app:        #f4f5f7;
  --bg-topbar:     #ffffff;
  --bg-list:       #ebecf0;
  --bg-card:       #ffffff;
  --bg-input:      #ffffff;
  --bg-hover:      #e4e6ea;
  --bg-active:     #dcdfe5;
  --bg-overlay:    rgba(0,0,0,.40);
  --border:        #d0d4db;
  --border-light:  #e4e6ea;
  --purple:        #7c5cbf;
  --purple-light:  #ede9f8;
  --purple-hover:  #6a4aad;
  --green-label:   #2e7d32;
  --orange-label:  #e65100;
  --yellow-label:  #f9a825;
  --red-label:     #c62828;
  --pink-label:    #c2185b;
  --blue-label:    #1565c0;
  --done-green:    #4caf50;
  --overdue-red:   #ef5350;
  --text-primary:  #172b4d;
  --text-secondary:#5e6c84;
  --text-muted:    #97a0af;
  --shadow-sm:     0 1px 3px rgba(0,0,0,.12);
  --shadow-md:     0 3px 8px  rgba(0,0,0,.14);
  --shadow-lg:     0 6px 20px rgba(0,0,0,.16);
  --shadow-xl:     0 12px 40px rgba(0,0,0,.18);
  --radius-sm:     6px;
  --radius:        8px;
  --radius-lg:     12px;
  --list-width:    300px;
  --topbar-h:      56px;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

body.dark {
  --bg-app:#0f1117; --bg-topbar:#1a1d27; --bg-list:#1e2130;
  --bg-card:#252a3a; --bg-input:#252a3a; --bg-hover:#2d3347;
  --bg-active:#333a52; --bg-overlay:rgba(0,0,0,.65);
  --border:#333a52; --border-light:#2d3347;
  --purple:#9d7fe0; --purple-light:rgba(157,127,224,.15); --purple-hover:#b494f0;
  --green-label:#4caf50; --orange-label:#ff9800; --yellow-label:#fdd835;
  --red-label:#ef5350; --pink-label:#f48fb1; --blue-label:#42a5f5;
  --done-green:#4caf50; --overdue-red:#ef5350;
  --text-primary:#e8eaf0; --text-secondary:#a8b2c8; --text-muted:#6b7694;
  --shadow-sm:0 1px 3px rgba(0,0,0,.4); --shadow-md:0 3px 8px rgba(0,0,0,.5);
  --shadow-lg:0 6px 20px rgba(0,0,0,.55); --shadow-xl:0 12px 40px rgba(0,0,0,.6);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{background:var(--bg-app);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;}
button{font-family:inherit;cursor:pointer;}
input,textarea,select{font-family:inherit;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}

/* ── Screens ── */
#authScreen{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--bg-app);}
#appScreen{display:none;flex-direction:column;height:100vh;overflow:hidden;}

/* ── Auth ── */
.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 40px;width:380px;max-width:95vw;box-shadow:var(--shadow-xl);}
.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px;}
.auth-logo-mark{width:44px;height:44px;border-radius:10px;background:var(--purple);color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;}
.auth-logo h1{font-size:22px;font-weight:800;color:var(--text-primary);}
.auth-logo p{font-size:12px;color:var(--text-muted);margin-top:2px;}
.auth-form{display:flex;flex-direction:column;gap:14px;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-group label{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;}
.form-group input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s;}
.form-group input:focus{border-color:var(--purple);}
.btn-primary{padding:10px 18px;background:var(--purple);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:700;transition:background .12s;}
.btn-primary:hover{background:var(--purple-hover);}
.auth-switch{font-size:13px;color:var(--text-muted);text-align:center;}
.auth-switch a{color:var(--purple);cursor:pointer;font-weight:600;text-decoration:none;}
.auth-switch a:hover{text-decoration:underline;}
.auth-error{font-size:13px;color:var(--overdue-red);min-height:18px;text-align:center;}

/* ── Top Bar ── */
.topbar{height:var(--topbar-h);flex-shrink:0;display:flex;align-items:center;gap:6px;padding:0 16px;background:var(--bg-topbar);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative;z-index:10;}
.topbar-logo{width:34px;height:34px;border-radius:50%;background:var(--purple);color:white;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;flex-shrink:0;margin-right:6px;}

.view-tabs{display:flex;gap:2px;flex-shrink:0;background:var(--bg-app);border:1px solid var(--border);border-radius:var(--radius);padding:3px;}
.view-tab{display:flex;align-items:center;gap:6px;padding:6px 11px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap;border:none;background:none;position:relative;}
.view-tab:hover{background:var(--bg-hover);color:var(--text-primary);}
.view-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm);}
.view-tab svg{width:15px;height:15px;opacity:.55;flex-shrink:0;}
.view-tab.active svg{opacity:1;}

.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;font-size:11px;font-weight:700;background:var(--overdue-red);color:white;margin-left:2px;}
.nav-badge.blue{background:var(--blue-label);}
.nav-badge.gray{background:var(--text-muted);}

.topbar-search{margin-left:auto;display:flex;align-items:center;gap:8px;padding:7px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-app);color:var(--text-muted);font-size:13px;min-width:180px;cursor:text;flex-shrink:1;transition:border-color .15s,background .15s;}
.topbar-search:hover,.topbar-search:focus-within{background:var(--bg-card);border-color:var(--purple);}
.topbar-search svg{width:14px;height:14px;opacity:.5;flex-shrink:0;}
.topbar-search input{border:none;background:transparent;outline:none;color:var(--text-primary);font:inherit;font-size:13px;width:100%;}
.topbar-search input::placeholder{color:var(--text-muted);}

.topbar-right{display:flex;align-items:center;gap:8px;margin-left:10px;flex-shrink:0;}
.topbar-btn{display:flex;align-items:center;gap:5px;height:34px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;transition:background .12s;white-space:nowrap;}
.topbar-btn:hover{background:var(--bg-hover);}
.topbar-btn svg{width:17px;height:17px;}
.topbar-btn.icon-only{width:34px;padding:0;justify-content:center;}

/* Modes */
.modes-wrapper{position:relative;}
.modes-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:6px;min-width:240px;z-index:200;display:none;}
.modes-dropdown.open{display:block;animation:popIn .15s ease;}
@keyframes popIn{from{opacity:0;transform:translateY(-6px) scale(.97);}to{opacity:1;transform:translateY(0) scale(1);}}
.modes-dropdown-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:4px 10px 8px;}
.modes-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s;}
.modes-item:hover{background:var(--bg-hover);}
.modes-item-info{flex:1;}
.modes-item-name{font-size:13px;font-weight:700;color:var(--text-primary);}
.modes-item-desc{font-size:11px;color:var(--text-muted);margin-top:1px;}
.modes-toggle{width:32px;height:18px;border-radius:999px;background:var(--border);position:relative;flex-shrink:0;transition:background .2s;}
.modes-toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:white;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.modes-toggle.on{background:var(--purple);}
.modes-toggle.on::after{transform:translateX(14px);}
.modes-divider{height:1px;background:var(--border-light);margin:4px 0;}

/* User pill */
.user-pill{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;border:1px solid var(--border);border-radius:999px;background:var(--bg-app);cursor:pointer;transition:background .12s;}
.user-pill:hover{background:var(--bg-hover);}
.uav{width:26px;height:26px;border-radius:50%;background:var(--purple);color:white;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;}
.uname{font-size:13px;font-weight:600;color:var(--text-primary);}

/* Sync dot */
.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--done-green);flex-shrink:0;transition:background .3s;}
.sync-dot.syncing{background:var(--yellow-label);animation:blink .8s infinite;}
.sync-dot.error{background:var(--overdue-red);}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ── Board ── */
.board{display:flex;gap:10px;padding:14px;height:calc(100vh - var(--topbar-h));overflow-x:auto;overflow-y:hidden;background:var(--bg-app);align-items:flex-start;}
.board::-webkit-scrollbar{height:8px;}
.board::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}

/* ── Special views ── */
.special-view{display:none;height:calc(100vh - var(--topbar-h));overflow-y:auto;background:var(--bg-app);}
.special-view.active{display:block;}

/* ── List ── */
.list{min-width:var(--list-width);max-width:var(--list-width);display:flex;flex-direction:column;max-height:100%;flex-shrink:0;background:var(--bg-list);border-radius:var(--radius-lg);}
.list-header{display:flex;align-items:center;gap:6px;padding:10px 12px;font-size:14px;font-weight:700;color:var(--text-primary);flex-shrink:0;cursor:grab;user-select:none;}
.list-header:active{cursor:grabbing;}
.list-icon{font-size:13px;opacity:.5;}
.card-count{font-size:13px;font-weight:600;color:var(--text-muted);margin-left:2px;}
.list-actions{margin-left:auto;display:flex;gap:2px;}
.list-actions button{width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:16px;transition:background .12s;}
.list-actions button:hover{background:var(--bg-hover);color:var(--text-primary);}

.list-cards{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 6px 12px;display:flex;flex-direction:column;gap:8px;min-height:40px;}
.list-cards::-webkit-scrollbar{width:4px;}
.list-cards .sortable-ghost{opacity:.3;}

.drop-placeholder{border:2px dashed var(--purple);border-radius:var(--radius);background:var(--purple-light);min-height:60px;flex-shrink:0;}

/* Add card */
.add-card-form{padding:6px 6px 8px;display:none;flex-direction:column;gap:6px;}
.add-card-form.open{display:flex;}
.add-card-input{width:100%;padding:10px 12px;border:2px solid var(--purple);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);font:inherit;font-size:13px;outline:none;resize:none;min-height:70px;}
.add-card-actions{display:flex;gap:6px;align-items:center;}
.btn-add-confirm{padding:7px 14px;background:var(--purple);color:white;border:none;border-radius:var(--radius-sm);font:inherit;font-size:13px;font-weight:700;transition:background .12s;}
.btn-add-confirm:hover{background:var(--purple-hover);}
.btn-add-cancel{width:30px;height:30px;border:none;background:transparent;color:var(--text-muted);font-size:20px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background .12s;}
.btn-add-cancel:hover{background:var(--bg-hover);color:var(--text-primary);}
.add-card-btn{display:flex;align-items:center;gap:8px;margin:0 6px 6px;padding:8px 10px;border:none;background:transparent;color:var(--text-secondary);font:inherit;font-size:13px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s;}
.add-card-btn:hover{background:var(--bg-hover);color:var(--text-primary);}
.add-card-btn svg{width:16px;height:16px;}

/* Add list */
.add-list{min-width:270px;max-width:270px;padding:4px;flex-shrink:0;}
.add-list-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;border:none;border-radius:var(--radius-lg);background:rgba(0,0,0,.06);color:var(--text-secondary);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s;}
.add-list-btn:hover{background:rgba(0,0,0,.10);}

/* ── Card ── */
.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);padding:12px;cursor:pointer;box-shadow:var(--shadow-sm);position:relative;user-select:none;transition:box-shadow .15s,transform .15s;}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);}
.card.sortable-chosen{opacity:.8;}
.card.sortable-ghost{opacity:.3;}

.card-labels{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap;}
.card-label{padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:700;color:white;}
.card-label.green{background:var(--green-label);}
.card-label.orange{background:var(--orange-label);}
.card-label.yellow{background:var(--yellow-label);color:#333;}
.card-label.red{background:var(--red-label);}
.card-label.pink{background:var(--pink-label);}
.card-label.blue{background:var(--blue-label);}
.card-label.purple{background:var(--purple-light);color:#5a3d8a;}

.card-menu-btn{position:absolute;top:8px;right:6px;width:24px;height:24px;border:none;background:transparent;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:15px;opacity:0;transition:opacity .12s;z-index:2;}
.card:hover .card-menu-btn{opacity:1;}
.card-title{font-size:13px;font-weight:700;color:var(--text-primary);line-height:1.4;margin-bottom:4px;}
.card-description{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px;}

.card-meta-icons{display:flex;align-items:center;gap:6px;margin-top:4px;color:var(--text-muted);font-size:12px;}
.meta-icon{display:flex;align-items:center;gap:3px;}
.meta-icon svg{width:13px;height:13px;opacity:.6;}

.card-dates{display:flex;align-items:center;gap:6px;font-size:11px;margin-top:6px;flex-wrap:wrap;}
.card-date{display:flex;align-items:center;gap:3px;padding:2px 6px;border-radius:4px;color:var(--text-secondary);background:var(--bg-list);}
.card-date svg{width:12px;height:12px;}
.card-date.overdue{color:var(--overdue-red);font-weight:700;}

.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;}
.card-footer-left{display:flex;align-items:center;gap:6px;}
.icon-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);}
.icon-btn svg{width:15px;height:15px;}
.card-footer-right{display:flex;align-items:center;}
.avatar{width:28px;height:28px;border-radius:50%;border:2px solid var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:white;margin-left:-6px;}
.avatar:first-child{margin-left:0;}

/* ── Card detail panel ── */
.card-detail-backdrop{position:fixed;inset:0;z-index:99;background:var(--bg-overlay);opacity:0;pointer-events:none;transition:opacity .25s;}
.card-detail-backdrop.open{opacity:1;pointer-events:auto;}

.card-detail-overlay{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:100vw;z-index:100;background:var(--bg-card);border-left:1px solid var(--border);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);overflow:hidden;}
.card-detail-overlay.open{transform:translateX(0);}

.detail-tabs{display:flex;border-bottom:1px solid var(--border-light);padding:0 16px;flex-shrink:0;}
.detail-tab{padding:13px 12px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;}
.detail-tab.active{color:var(--text-primary);border-bottom-color:var(--purple);}
.detail-tab-spacer{flex:1;}
.detail-close{width:30px;height:30px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;align-self:center;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-muted);transition:background .12s;}
.detail-close:hover{background:var(--bg-hover);}

.detail-toolbar{display:flex;align-items:center;gap:2px;padding:8px 14px;border-bottom:1px solid var(--border-light);flex-shrink:0;flex-wrap:wrap;}
.detail-toolbar-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;font:inherit;font-size:13px;font-weight:600;color:var(--text-secondary);transition:background .12s;white-space:nowrap;}
.detail-toolbar-btn:hover{background:var(--bg-hover);}
.detail-toolbar-btn svg{width:15px;height:15px;}
.detail-toolbar-btn.done-btn{color:var(--done-green);}
.detail-toolbar-btn.danger-btn{color:var(--overdue-red);}
.detail-spacer{flex:1;}

.detail-scroll{flex:1;overflow-y:auto;display:flex;}
.detail-main{flex:1;padding:16px;min-width:0;}
.detail-sidebar{width:168px;padding:14px 12px;border-left:1px solid var(--border-light);flex-shrink:0;}

.detail-title-input{width:100%;font:inherit;font-size:16px;font-weight:800;color:var(--text-primary);border:none;background:transparent;outline:none;padding:0;margin-bottom:12px;resize:none;line-height:1.4;}
.detail-title-input:focus{border-bottom:2px solid var(--purple);}

.detail-meta-row{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap;}
.detail-avatar{width:30px;height:30px;border-radius:50%;background:var(--purple);color:white;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;flex-shrink:0;}
.detail-meta-info{font-size:12px;color:var(--text-muted);line-height:1.5;}
.detail-meta-info strong{display:block;font-size:13px;color:var(--text-primary);}
.detail-list-select{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;font-size:13px;color:var(--text-secondary);background:var(--bg-card);cursor:pointer;margin-left:auto;}

.detail-priority-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;font-size:13px;color:var(--text-secondary);background:var(--bg-card);cursor:pointer;margin-bottom:12px;width:100%;transition:border-color .12s;}
.detail-priority-btn:hover{border-color:var(--purple);}
.p-circle{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;transition:all .15s;}

.detail-card-labels{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap;align-items:center;}
.detail-add-label{width:22px;height:22px;border-radius:50%;border:1px dashed var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--text-muted);background:none;transition:border-color .12s,color .12s;}
.detail-add-label:hover{border-color:var(--purple);color:var(--purple);}

.detail-desc{background:var(--bg-app);border-radius:var(--radius);padding:14px;margin-bottom:14px;font-size:13px;line-height:1.7;color:var(--text-primary);}
.detail-desc-textarea{width:100%;font:inherit;font-size:13px;line-height:1.7;color:var(--text-primary);border:none;background:transparent;outline:none;resize:vertical;min-height:80px;}
.detail-desc-textarea::placeholder{color:var(--text-muted);}

.detail-section{margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border-light);}
.detail-section:last-child{border-bottom:none;}
.detail-section-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.plus-btn{width:20px;height:20px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--text-muted);margin-left:auto;background:none;transition:border-color .12s,color .12s;}
.plus-btn:hover{border-color:var(--purple);color:var(--purple);}

.detail-due-input{padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;font-size:13px;color:var(--text-primary);background:var(--bg-card);cursor:pointer;outline:none;}
.detail-due-input:focus{border-color:var(--purple);}

.sidebar-group-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;margin-top:14px;}
.sidebar-group-title:first-child{margin-top:0;}
.sidebar-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:background .12s;}
.sidebar-item:hover{background:var(--bg-hover);}
.sidebar-item svg{width:15px;height:15px;opacity:.5;flex-shrink:0;}

/* Attachments */
.att-item{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--bg-app);border-radius:var(--radius-sm);font-size:13px;margin-bottom:4px;}
.att-link{color:var(--purple);text-decoration:none;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.att-link:hover{text-decoration:underline;}
.att-size{font-size:11px;color:var(--text-muted);white-space:nowrap;}
.att-empty,.att-loading{font-size:12px;color:var(--text-muted);font-style:italic;padding:6px 0;}
.btn-attach{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px dashed var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .12s;}
.btn-attach:hover{border-color:var(--purple);color:var(--purple);}

/* ── Context menu ── */
.dropdown-menu{position:fixed;z-index:300;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--border);padding:6px;min-width:220px;display:none;max-height:80vh;overflow-y:auto;}
.dropdown-menu.open{display:block;animation:popIn .12s ease;}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);cursor:pointer;transition:background .1s;}
.dropdown-item:hover{background:var(--bg-hover);}
.dropdown-item svg{width:16px;height:16px;color:var(--text-muted);flex-shrink:0;}
.dropdown-item.danger{color:var(--overdue-red);}
.dropdown-item.danger svg{color:var(--overdue-red);}
.dropdown-divider{height:1px;background:var(--border-light);margin:4px 6px;}
.dropdown-color-row{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--text-secondary);}
.color-dot{width:24px;height:24px;border-radius:50%;cursor:pointer;transition:transform .12s;flex-shrink:0;border:2px solid transparent;}
.color-dot:hover{transform:scale(1.15);}
.color-dot.selected{border-color:var(--text-primary);}
.color-dot.orange{background:var(--orange-label);}
.color-dot.yellow{background:var(--yellow-label);}
.color-dot.green{background:var(--done-green);}
.color-dot.blue{background:var(--blue-label);}
.color-dot.red{background:var(--red-label);}
.color-dot.purple{background:var(--purple);}

/* ── Toast ── */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(120px);z-index:500;background:#1e2a3a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:12px 20px;display:flex;align-items:center;gap:12px;color:white;font-size:13px;font-weight:600;box-shadow:var(--shadow-xl);transition:transform .25s ease,visibility .25s;visibility:hidden;pointer-events:none;max-width:calc(100vw - 32px);}
.toast.show{transform:translateX(-50%) translateY(0);visibility:visible;pointer-events:auto;}
.toast-icon{font-size:16px;}
.toast-btns{display:flex;gap:8px;margin-left:8px;}
.toast-btn{padding:5px 12px;border-radius:var(--radius-sm);font:inherit;font-size:12px;font-weight:700;cursor:pointer;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:white;transition:background .12s;}
.toast-btn:hover{background:rgba(255,255,255,.2);}
.toast-btn.undo{background:var(--purple);border-color:var(--purple);}

/* ── Special view layout ── */
.special-header{padding:20px 24px 16px;display:flex;align-items:center;gap:12px;background:var(--bg-topbar);border-bottom:1px solid var(--border);}
.special-header h2{font-size:18px;font-weight:800;color:var(--text-primary);flex:1;}
.special-search{padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);font:inherit;font-size:13px;outline:none;width:260px;}
.special-search:focus{border-color:var(--purple);}
.special-wrap{padding:16px 24px;}
.special-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:box-shadow .15s;}
.special-card:hover{box-shadow:var(--shadow-sm);}
.special-card-info{flex:1;min-width:0;}
.special-card-title{font-size:14px;font-weight:700;color:var(--text-primary);}
.special-card-meta{font-size:12px;color:var(--text-muted);margin-top:3px;}
.special-card-actions{display:flex;gap:6px;flex-shrink:0;}
.special-btn{padding:5px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font:inherit;font-size:12px;font-weight:700;cursor:pointer;color:var(--text-secondary);transition:all .12s;}
.special-btn:hover{border-color:var(--purple);color:var(--purple);}
.special-btn.restore{color:var(--done-green);}
.special-btn.restore:hover{border-color:var(--done-green);background:rgba(76,175,80,.06);}
.special-btn.del-perm{color:var(--overdue-red);}
.special-btn.del-perm:hover{border-color:var(--overdue-red);}
.pager{display:flex;align-items:center;gap:10px;padding:12px 0;font-size:13px;color:var(--text-muted);}
.pager button{padding:5px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font:inherit;font-size:12px;cursor:pointer;color:var(--text-secondary);transition:all .12s;}
.pager button:hover{border-color:var(--purple);color:var(--purple);}
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:14px;}
.empty-state .empty-icon{font-size:40px;margin-bottom:12px;}
.empty-state h3{font-size:16px;font-weight:700;color:var(--text-secondary);margin-bottom:6px;}
