/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --brand: #6366F1;
  --brand-dark: #4F46E5;
  --brand-light: #EEF2FF;
  --text: #111827;
  --text-secondary: #6B7280;
  --border: #E5E7EB;
  --bg: #F9FAFB;
  --card: #FFFFFF;
  --danger: #EF4444;
  --radius: 10px;
  --shadow: 0 1px 4px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.12);
  --sidebar-w: 230px;
  --topbar-h: 58px;
}

html, body { height:100%; font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; font-size:14px; color:var(--text); background:var(--bg); line-height:1.5; }

/* ===== SCREENS ===== */
.screen { display:none; height:100vh; }
.screen.active { display:flex; }

/* ===== AUTH ===== */
#auth-screen { align-items:center; justify-content:center; background:linear-gradient(135deg,#EEF2FF 0%,#F9FAFB 60%,#E0E7FF 100%); }

.auth-box { background:var(--card); border-radius:16px; box-shadow:var(--shadow-lg); padding:36px; width:400px; max-width:95vw; }
.auth-logo { display:flex; align-items:center; gap:10px; font-size:20px; font-weight:700; color:var(--brand); margin-bottom:28px; }
.auth-tabs { display:flex; gap:4px; background:var(--bg); border-radius:8px; padding:4px; margin-bottom:24px; }
.auth-tab { flex:1; padding:7px; border:none; background:transparent; border-radius:6px; cursor:pointer; font-size:13px; font-weight:500; color:var(--text-secondary); transition:all .15s; }
.auth-tab.active { background:var(--card); color:var(--text); box-shadow:0 1px 3px rgba(0,0,0,.1); }
.auth-form { display:none; flex-direction:column; gap:14px; }
.auth-form.active { display:flex; }
.auth-error { color:var(--danger); font-size:13px; min-height:18px; }

/* ===== LAYOUT ===== */
#app-screen { flex-direction:row; overflow:hidden; }

/* ===== SIDEBAR ===== */
.sidebar { width:var(--sidebar-w); min-width:var(--sidebar-w); background:var(--card); border-right:1px solid var(--border); display:flex; flex-direction:column; padding:16px 10px; gap:2px; overflow-y:auto; }
.sidebar-logo { display:flex; align-items:center; gap:10px; font-size:16px; font-weight:700; color:var(--brand); padding:4px 8px 16px; }
.sidebar-nav { display:flex; flex-direction:column; gap:2px; }

.sidebar-section-title { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text-secondary); padding:10px 12px 6px; margin-top:4px; }

.dept-filters { display:flex; flex-direction:column; gap:2px; margin-bottom:4px; }
.dept-filter-item {
  display:flex; align-items:center; gap:8px; padding:6px 12px;
  border-radius:8px; cursor:pointer; font-size:13px; font-weight:500; color:var(--text-secondary);
  transition:background .1s; user-select:none;
}
.dept-filter-item:hover { background:var(--bg); }
/* Чекбокс — видимый, справа */
.dept-filter-item input[type=checkbox] {
  margin-left:auto;
  width:15px; height:15px;
  accent-color:var(--brand);
  cursor:pointer;
  flex-shrink:0;
}
.dept-filter-item input:checked + .dept-label { color:var(--text); font-weight:600; }
.dept-label { flex:1; }
.dept-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }

.nav-item { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:8px; border:none; background:transparent; cursor:pointer; font-size:13.5px; font-weight:500; color:var(--text-secondary); text-align:left; width:100%; transition:all .15s; font-family:inherit; }
.nav-item:hover { background:var(--bg); color:var(--text); }
.nav-item.active { background:var(--brand-light); color:var(--brand); }
.board-filter.active-board { background:var(--brand-light); color:var(--brand); }
.board-filter.disabled { opacity:.45; cursor:not-allowed; }
.board-filter.disabled input { pointer-events:none; }

.sidebar-bottom { display:flex; flex-direction:column; gap:2px; padding-top:10px; border-top:1px solid var(--border); margin-top:auto; }
.user-avatar-wrap { display:flex; align-items:center; gap:10px; padding:8px 12px; border-radius:8px; cursor:pointer; transition:background .15s; }
.user-avatar-wrap:hover { background:var(--bg); }
.user-info { display:flex; flex-direction:column; min-width:0; }
.user-info span:first-child { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:120px; }

/* ===== AVATAR ===== */
.avatar { width:36px; height:36px; border-radius:50%; background:var(--brand); color:white; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; flex-shrink:0; overflow:hidden; position:relative; }
.avatar.large { width:72px; height:72px; font-size:34px; }
.preset-animal { line-height:1; }
.preset-mark { position:absolute; right:-1px; bottom:-1px; min-width:14px; height:14px; border-radius:7px; display:flex; align-items:center; justify-content:center; padding:0 3px; background:var(--av-fg,currentColor); color:white; border:1px solid white; font-size:7px; font-weight:800; letter-spacing:-.02em; }
.avatar .preset-mark { right:1px; bottom:1px; }
.avatar.large .preset-mark { right:4px; bottom:4px; min-width:20px; height:20px; border-radius:10px; font-size:9px; }

/* ===== ROLE BADGE ===== */
.role-badge { font-size:10px; font-weight:600; padding:1px 6px; border-radius:4px; background:var(--brand-light); color:var(--brand); text-transform:uppercase; letter-spacing:.04em; width:fit-content; }

/* ===== DEPT BADGE ===== */
.dept-badge { display:inline-block; font-size:11px; font-weight:600; padding:2px 8px; border-radius:4px; }

/* ===== MAIN ===== */
.main { flex:1; display:flex; flex-direction:column; overflow:hidden; }

/* ===== TOPBAR ===== */
.topbar { height:var(--topbar-h); display:flex; align-items:center; justify-content:space-between; padding:0 20px; border-bottom:1px solid var(--border); background:var(--card); gap:12px; flex-shrink:0; }
.topbar-left { display:flex; align-items:center; gap:6px; }
.topbar-left h2 { font-size:15px; font-weight:600; min-width:180px; }
.topbar-right { display:flex; align-items:center; gap:8px; }

/* ===== FILTER WRAP ===== */
.filter-wrap { position:relative; }
.btn-ghost.icon-text { display:flex; align-items:center; gap:6px; font-size:13px; padding:7px 12px; }
.filter-count { background:var(--brand); color:white; border-radius:10px; font-size:10px; font-weight:700; padding:1px 5px; min-width:18px; text-align:center; }

.filter-dropdown { position:absolute; top:calc(100% + 6px); right:0; background:var(--card); border:1px solid var(--border); border-radius:10px; box-shadow:var(--shadow-lg); min-width:180px; z-index:200; overflow:hidden; }
.filter-drop-item { display:flex; align-items:center; gap:8px; padding:9px 14px; cursor:pointer; user-select:none; font-size:13px; transition:background .1s; }
.filter-drop-item:hover { background:var(--bg); }
.filter-drop-item input { accent-color:var(--brand); cursor:pointer; }

/* ===== CALENDAR VIEWS ===== */
.calendar-view { display:none; flex:1; overflow:auto; padding:20px 20px 20px 20px; }
.calendar-view.active { display:flex; flex-direction:column; }

/* ===== WEEK VIEW ===== */
.week-day-header {
  display:grid; grid-template-columns:80px repeat(7,1fr);
  border-bottom:2px solid var(--border); background:var(--card);
  position:sticky; top:-20px; z-index:10;
  margin:-20px -20px 0; padding:0 20px;
}
.week-day-head { padding:10px 6px; text-align:center; }
.wdh-name { font-size:10px; text-transform:uppercase; letter-spacing:.05em; color:var(--text-secondary); font-weight:600; }
.day-num { display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; font-size:15px; font-weight:600; margin-top:3px; }
.week-day-head.today .day-num { background:var(--brand); color:white; }

/* Slot rows */
.slot-row {
  display:grid;
  grid-template-columns:80px repeat(7,1fr);
  border-bottom:2px solid var(--border);
  min-height:120px;
}
.slot-row:last-child { border-bottom:none; }

.slot-label {
  display:flex; flex-direction:column; justify-content:flex-start;
  align-items:flex-end; gap:2px;
  padding:12px 10px 12px 4px;
  border-right:2px solid var(--border);
  background:var(--card);
  position:sticky; left:0; z-index:5;
}
.slot-name { font-size:12px; font-weight:700; color:var(--text); }
.slot-range { font-size:10px; color:var(--text-secondary); white-space:nowrap; }

.slot-cell {
  border-left:1px solid var(--border);
  padding:6px 5px;
  display:flex; flex-direction:column; gap:5px;
  min-height:120px;
  position:relative;
  transition:background .1s;
}
.slot-cell.today-col { background:rgba(99,102,241,.025); }
.slot-cell:hover { background:rgba(99,102,241,.02); }

/* ── TICKET (week) ─────────────────────────────────── */
.week-ticket {
  position:relative;
  border-radius:8px;
  padding:8px 10px;
  cursor:pointer;
  border-left:3px solid transparent;
  box-shadow:0 1px 3px rgba(0,0,0,.08);
  overflow:visible;
  user-select:none;
  transition:box-shadow .12s, transform .12s;
  display:flex;
  flex-direction:column;
  gap:5px;
  width:100%;
  box-sizing:border-box;
  /* Квадратный минимум — примерно 90px ширина ≈ высота */
  min-height:90px;
}
.week-ticket:hover { box-shadow:0 4px 14px rgba(0,0,0,.16); transform:translateY(-1px); z-index:10; }
.week-ticket:active { cursor:grabbing; }
.week-ticket.done-ticket,
.month-ticket.done-ticket { filter:grayscale(.35); opacity:.72; }
.week-ticket.done-ticket .t-title,
.month-ticket.done-ticket { color:#6B7280; }

.t-top-row { display:flex; align-items:center; gap:4px; flex-wrap:nowrap; }
.t-time { font-size:10px; font-weight:700; color:var(--text-secondary); flex-shrink:0; white-space:nowrap; }
.t-dots { display:flex; gap:3px; flex:1; }
.tdot { display:inline-block; width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.t-views-badge { display:flex; align-items:center; gap:2px; font-size:10px; font-weight:600; color:var(--text-secondary); background:rgba(0,0,0,.06); border-radius:4px; padding:1px 4px; white-space:nowrap; flex-shrink:0; }

/* Заголовок — показывает весь текст, без обрезки */
.t-title {
  font-size:12px;
  font-weight:600;
  line-height:1.35;
  color:var(--text);
  white-space:normal;
  word-break:break-word;
  flex:1;
}

.t-bottom-row { display:flex; align-items:center; justify-content:space-between; gap:4px; }
.t-author { font-size:10px; color:var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:70%; }
.t-members { display:flex; }
.tmini-av { width:16px; height:16px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:8px; font-weight:700; color:white; border:1px solid white; margin-left:-4px; flex-shrink:0; position:relative; overflow:hidden; }
.tmini-av:first-child { margin-left:0; }
.tmini-av.preset-av { background:var(--av-bg,#F3F4F6); color:var(--av-fg,inherit); font-size:11px; }
.tmini-av .preset-mark { display:none; }
.ticket-progress-mini { height:4px; border-radius:999px; background:rgba(17,24,39,.08); overflow:hidden; }
.ticket-progress-mini span { display:block; height:100%; border-radius:999px; background:#6366F1; }
.done-ticket .ticket-progress-mini span { background:#9CA3AF; }
.t-status { font-size:9px; line-height:1.2; color:var(--text-secondary); font-weight:600; }

/* ── MONTH TICKET ─── */
.month-ticket { border-radius:5px; padding:3px 7px; font-size:11px; font-weight:500; margin-bottom:2px; cursor:pointer; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; transition:opacity .1s; border-left:3px solid transparent; }
.month-ticket:hover { opacity:.85; }
.mt-time { font-size:10px; opacity:.7; font-weight:600; }
.mt-status { display:block; font-size:9px; color:var(--text-secondary); margin-top:1px; }

/* ===== MONTH GRID ===== */
.month-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:1px; background:var(--border); border-radius:var(--radius); overflow:hidden; flex:1; }
.month-day-head { background:var(--card); padding:8px; text-align:center; font-size:11px; font-weight:700; color:var(--text-secondary); text-transform:uppercase; letter-spacing:.05em; }
.month-cell { background:var(--card); padding:7px; min-height:100px; position:relative; cursor:pointer; transition:background .1s; overflow:hidden; }
.month-cell:hover { background:#FAFAFA; }
.month-cell.other-month .cell-day-num { color:#D1D5DB; }
.month-cell.today .cell-day-num { background:var(--brand); color:white; border-radius:50%; }
.cell-day-num { font-size:13px; font-weight:600; color:var(--text); margin-bottom:4px; width:24px; height:24px; display:flex; align-items:center; justify-content:center; }
.month-more { font-size:11px; color:var(--text-secondary); margin-top:2px; cursor:pointer; }

/* ===== YEAR VIEW ===== */
.year-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; flex:1; }
.year-month-card { background:var(--card); border-radius:var(--radius); border:1px solid var(--border); padding:12px; cursor:pointer; transition:box-shadow .15s,transform .15s; }
.year-month-card:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
.year-month-title { font-size:12px; font-weight:700; margin-bottom:8px; text-transform:capitalize; }
.year-mini-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.year-mini-head { font-size:8px; text-align:center; color:var(--text-secondary); font-weight:600; padding:1px 0; }
.year-mini-day { width:100%; aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-size:8.5px; border-radius:3px; position:relative; }
.year-mini-day.other { color:#D1D5DB; }
.year-mini-day.today { background:var(--brand); color:white; border-radius:50%; }
.year-mini-day.has-tickets::after { content:''; position:absolute; bottom:1px; left:50%; transform:translateX(-50%); width:4px; height:4px; background:var(--brand); border-radius:50%; }
.year-mini-day.today.has-tickets::after { background:white; }

/* ===== FIELDS ===== */
.field { display:flex; flex-direction:column; gap:5px; }
.field label { font-size:11px; font-weight:700; color:var(--text-secondary); text-transform:uppercase; letter-spacing:.04em; }
.field input, .field select, .field textarea { padding:9px 12px; border:1.5px solid var(--border); border-radius:8px; font-size:14px; color:var(--text); background:var(--bg); outline:none; transition:border-color .15s; font-family:inherit; }
.field input:focus, .field select:focus, .field textarea:focus { border-color:var(--brand); background:white; }
.field input[disabled] { opacity:.5; cursor:not-allowed; }
.field-row { display:flex; gap:12px; }
.field-row .field { flex:1; }
.req { color:var(--danger); }

/* ===== BUTTONS ===== */
.btn-primary { background:var(--brand); color:white; border:none; border-radius:8px; padding:9px 18px; font-size:14px; font-weight:600; cursor:pointer; transition:background .15s,transform .1s; white-space:nowrap; font-family:inherit; }
.btn-primary:hover { background:var(--brand-dark); }
.btn-primary:active { transform:scale(.97); }
.btn-primary.full { width:100%; padding:11px; }
.btn-primary.small { padding:6px 12px; font-size:12px; }

.btn-ghost { background:transparent; color:var(--text); border:1.5px solid var(--border); border-radius:8px; padding:9px 18px; font-size:14px; font-weight:500; cursor:pointer; transition:background .15s,border-color .15s; white-space:nowrap; font-family:inherit; }
.btn-ghost:hover { background:var(--bg); border-color:#D1D5DB; }
.btn-ghost.small { padding:5px 10px; font-size:12px; }
.btn-ghost.danger { color:var(--danger); }
.btn-ghost.danger:hover { background:#FEF2F2; border-color:#FCA5A5; }

.icon-btn { display:flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:8px; border:none; background:transparent; cursor:pointer; color:var(--text-secondary); transition:background .15s,color .15s; }
.icon-btn:hover { background:var(--bg); color:var(--text); }

/* ===== MODALS ===== */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.4); display:flex; align-items:center; justify-content:center; z-index:1000; backdrop-filter:blur(2px); }
.modal-overlay.hidden { display:none; }
.modal { background:var(--card); border-radius:16px; box-shadow:var(--shadow-lg); width:480px; max-width:95vw; max-height:90vh; display:flex; flex-direction:column; overflow:hidden; animation:modal-in .18s ease; }
.modal.wide { width:560px; }
.modal.small { width:360px; }
@keyframes modal-in { from { opacity:0; transform:scale(.96) translateY(8px); } to { opacity:1; transform:scale(1) translateY(0); } }
.modal-header { display:flex; align-items:center; justify-content:space-between; padding:18px 20px 14px; border-bottom:1px solid var(--border); }
.modal-header h3 { font-size:16px; font-weight:700; }
.modal-body { padding:20px; overflow-y:auto; display:flex; flex-direction:column; gap:14px; flex:1; }
.modal-footer { display:flex; align-items:center; padding:14px 20px; border-top:1px solid var(--border); gap:8px; }

/* ===== TAGS ===== */
.tags-chips, .members-chips { display:flex; flex-wrap:wrap; gap:6px; min-height:28px; }
.tag-chip { display:inline-flex; align-items:center; gap:5px; padding:3px 10px; border-radius:20px; font-size:12px; font-weight:600; cursor:default; border:1px solid transparent; }
.tag-remove { font-size:14px; line-height:1; margin-left:2px; opacity:.6; cursor:pointer; }
.tag-remove:hover { opacity:1; }

/* Member chips */
.member-chip { display:inline-flex; align-items:center; gap:6px; padding:3px 10px 3px 4px; border-radius:20px; font-size:12px; font-weight:500; background:var(--bg); border:1px solid var(--border); }
.mchip-av { width:22px; height:22px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:9px; font-weight:700; color:white; flex-shrink:0; position:relative; overflow:hidden; }
.mchip-av.small { width:20px; height:20px; font-size:9px; }
.mchip-av.preset-av { background:var(--av-bg,#F3F4F6); color:var(--av-fg,inherit); font-size:15px; }
.mchip-av.small.preset-av { font-size:14px; }
.mchip-av .preset-mark { display:none; }

.tags-select-wrap, .members-wrap { display:flex; flex-direction:column; gap:8px; }
.member-actions { display:flex; flex-wrap:wrap; gap:6px; }

/* Progress preview */
.progress-preview { display:flex; flex-direction:column; gap:6px; margin-top:4px; }
.progress-step { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--text-secondary); }
.progress-dot { width:10px; height:10px; border-radius:50%; background:#D1D5DB; flex-shrink:0; }
.progress-step.active .progress-dot { background:var(--brand); }
.progress-step.current .progress-label { color:var(--text); font-weight:700; }

/* Comments */
.comments-section { background:var(--bg); border:1px solid var(--border); border-radius:10px; padding:14px; display:flex; flex-direction:column; gap:10px; }
.comments-header { font-size:12px; font-weight:700; color:var(--text-secondary); text-transform:uppercase; letter-spacing:.04em; }
.comments-list { display:flex; flex-direction:column; gap:8px; max-height:220px; overflow:auto; }
.comment-item { background:var(--card); border:1px solid var(--border); border-radius:8px; padding:8px 10px; }
.comment-meta { display:flex; justify-content:space-between; gap:8px; font-size:11px; color:var(--text-secondary); margin-bottom:4px; }
.comment-meta strong { color:var(--text); }
.comment-text { font-size:13px; white-space:pre-wrap; word-break:break-word; }
.empty-comments { color:var(--text-secondary); font-size:13px; }
.comment-form { display:flex; gap:8px; align-items:flex-end; }
.comment-form textarea { flex:1; padding:8px 10px; border:1.5px solid var(--border); border-radius:8px; resize:vertical; font-family:inherit; background:white; }

/* Tags management */
.tag-manage-item { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--border); }
.tag-manage-item:last-child { border-bottom:none; }
.tag-color-dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.tag-manage-name { flex:1; font-size:13px; font-weight:500; }
.tag-delete-btn { border:none; background:none; color:var(--text-secondary); cursor:pointer; font-size:16px; padding:2px 6px; border-radius:4px; transition:color .1s,background .1s; }
.tag-delete-btn:hover { color:var(--danger); background:#FEF2F2; }
.new-tag-form { display:flex; gap:8px; align-items:center; margin-top:12px; padding-top:12px; border-top:1px solid var(--border); }
.new-tag-form input[type=text] { flex:1; padding:8px 12px; border:1.5px solid var(--border); border-radius:8px; font-size:13px; outline:none; font-family:inherit; }
.new-tag-form input[type=text]:focus { border-color:var(--brand); }
.new-tag-form input[type=color] { width:36px; height:36px; border:1.5px solid var(--border); border-radius:8px; cursor:pointer; padding:2px; background:white; }

/* Tag picker / member picker items */
.tag-picker-item { display:flex; align-items:center; gap:10px; padding:9px 4px; border-bottom:1px solid var(--border); cursor:pointer; border-radius:6px; transition:background .1s; user-select:none; }
.tag-picker-item:last-child { border-bottom:none; }
.tag-picker-item:hover { background:var(--bg); }
.tag-picker-item input[type=checkbox] { width:16px; height:16px; cursor:pointer; accent-color:var(--brand); flex-shrink:0; }

/* ===== TICKET META ===== */
.ticket-meta { font-size:12px; color:var(--text-secondary); line-height:2; display:flex; flex-direction:column; gap:2px; }
.ticket-meta strong { color:var(--text); }

/* ===== ANALYTICS ===== */
.analytics-section { background:var(--bg); border-radius:10px; padding:14px; display:flex; flex-direction:column; gap:12px; border:1px solid var(--border); }
.analytics-header { display:flex; align-items:center; gap:6px; font-size:12px; font-weight:700; color:var(--text-secondary); text-transform:uppercase; letter-spacing:.04em; }
.analytics-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.stat-card { background:var(--card); border-radius:8px; padding:10px 12px; border:1px solid var(--border); text-align:center; }
.stat-value { font-size:20px; font-weight:700; color:var(--text); }
.stat-label { font-size:11px; color:var(--text-secondary); margin-top:2px; }
.analytics-update-info { font-size:11px; color:var(--text-secondary); text-align:right; }

/* ===== EXPORT MODAL ===== */
.export-options { display:flex; flex-direction:column; gap:8px; margin:8px 0 12px; }
.export-option { display:flex; align-items:center; gap:8px; font-size:13px; cursor:pointer; padding:6px 0; }
.export-option input { accent-color:var(--brand); width:16px; height:16px; cursor:pointer; }

/* ===== PROFILE ===== */
.profile-avatar-section { display:flex; align-items:center; gap:16px; }
.profile-avatar-actions { display:flex; flex-direction:column; gap:6px; }
.avatar-note { color:var(--text-secondary); font-size:13px; max-width:260px; line-height:1.4; }
.avatar-preset-grid { display:grid; grid-template-columns:repeat(10,1fr); gap:6px; }
.avatar-preset-btn { height:38px; border:1.5px solid var(--border); background:var(--av-bg,var(--card)); color:var(--av-fg,var(--text)); border-radius:10px; cursor:pointer; font-size:20px; display:flex; align-items:center; justify-content:center; transition:background .12s,border-color .12s,transform .12s; position:relative; overflow:hidden; }
.avatar-preset-btn:hover { transform:translateY(-1px); }
.avatar-preset-btn.active { border-color:var(--brand); background:var(--brand-light); }
.avatar-preset-btn .preset-mark { right:1px; bottom:1px; }
.divider { height:1px; background:var(--border); margin:4px 0; }

/* ===== DRAG ===== */
.dragging { opacity:.5; transform:scale(1.03) translateY(-2px) !important; box-shadow:var(--shadow-lg) !important; z-index:999; }
.drop-target { background:rgba(99,102,241,.06) !important; outline:2px dashed var(--brand); outline-offset:-2px; }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:#D1D5DB; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:#9CA3AF; }
