:root {
  --blue: #00d4ff;
  --primary-rgb: 0, 212, 255;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font-family: 'Albert Sans', sans-serif; color: #111827; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.admin-body,
.admin-auth-body {
  background: #f3f5fb;
}

.admin-shell {
  min-height: 100vh;
}

.admin-sidebar {
  background: #0d1322;
  color: #fff;
  padding: 28px 20px;
  position: fixed;
  top: 0;
  left: 0;
  width: 280px;
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.admin-brand {
  display: flex;
  justify-content: center;
  margin-bottom: 34px;
}


.logo-slot {
  width: 100%;
  max-width: 180px;
  min-height: 72px;
  border-radius: 0;
  border: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.logo-slot img {
  width: 100%;
  max-width: 180px;
  max-height: 92px;
  object-fit: contain;
  object-position: center;
}
.auth-logo-slot {
  max-width: 190px;
  min-height: 76px;
}
.project-grid {
  align-items: stretch;
}
.project-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.project-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: auto;
  padding-top: 8px;
}
.attachments-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.attachment-item {
  border: 1px solid #ece7f8;
  border-radius: 10px;
  padding: 14px 16px;
  background: #fcfbff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.attachment-item-meta {
  min-width: 0;
}
.attachment-item-name {
  font-weight: 700;
  word-break: break-word;
}
.attachment-item-size {
  color: #7b8497;
  font-size: 13px;
  margin-top: 4px;
}

.admin-nav { display: flex; flex-direction: column; gap: 8px; flex: 1; min-height: 0; }
.admin-nav-main { display: grid; gap: 8px; }
.admin-nav-group-bottom { margin-top: auto; }
.admin-nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 10px;
  color: rgba(255,255,255,.88);
  font-weight: 600;
}
.admin-nav a:hover,
.admin-nav a.is-active { background: rgba(255,255,255,.08); color: #fff; }

.admin-nav-group {
  display: grid;
  gap: 8px;
}

.admin-nav-group-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: rgba(255,255,255,.88);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  text-align: left;
  appearance: none;
  -webkit-appearance: none;
}
.admin-nav-group-trigger span {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.admin-nav-group-trigger:hover,
.admin-nav-group.is-open .admin-nav-group-trigger {
  background: rgba(255,255,255,.08);
  color: #fff;
}
.admin-nav-group-trigger > i {
  font-size: 12px;
  color: rgba(255,255,255,.72);
  transition: transform .2s ease;
}
.admin-nav-group.is-open .admin-nav-group-trigger > i {
  transform: rotate(180deg);
}
.admin-nav-submenu {
  display: none;
  padding-left: 12px;
}
.admin-nav-group.is-open .admin-nav-submenu {
  display: grid;
}
.admin-nav-submenu a {
  padding-left: 18px;
}

.admin-main {
  min-width: 0;
  margin-left: 280px;
}

.admin-topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid #e8ebf3;
  padding: 20px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.admin-topbar-title {
  color: #1f2937;
}
.admin-topbar-right {
  display: flex;
  align-items: center;
  gap: 14px;
}
.admin-content { padding: 28px; }

.admin-user-menu {
  position: relative;
}
.admin-user-trigger {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #fff;
  font: inherit;
  font-weight: 700;
  color: #1f2937;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .04);
}
.admin-user-trigger-name {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.admin-user-trigger-chevron {
  color: #94a3b8;
  font-size: 12px;
}
.admin-user-crown {
  color: #f5b731;
}
.admin-user-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 14px);
  right: 0;
  min-width: 290px;
  background: #fff;
  border: 1px solid #e6eaf2;
  border-radius: 14px;
  padding: 18px 16px;
  box-shadow: 0 24px 60px rgba(15, 23, 42, .12);
}
.admin-user-menu.is-open .admin-user-dropdown {
  display: block;
}
.admin-user-dropdown-head {
  display: grid;
  gap: 4px;
  padding: 0 10px 14px;
}
.admin-user-dropdown-head strong {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}
.admin-user-dropdown-head span {
  color: #94a3b8;
  font-size: 14px;
}
.admin-user-dropdown-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 10px;
  border-radius: 14px;
  color: #1f2937;
  font-weight: 700;
}
.admin-user-dropdown-link i {
  color: #ea580c;
}
.admin-user-dropdown-link:hover {
  background: #f8fafc;
}
.admin-user-dropdown-separator {
  height: 1px;
  background: #e5e7eb;
  margin: 10px 0;
}

.auth-split-page {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(320px, 42%) 1fr;
}
.auth-split-visual {
  background: linear-gradient(180deg, #00d4ff 0%, #00a9cc 100%);
  color: #fff;
  padding: 42px 38px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.auth-split-brand img {
  width: 170px;
}
.auth-split-copy {
  margin-top: 88px;
  max-width: 440px;
  position: relative;
  z-index: 2;
}
.auth-split-copy h1 {
  font-size: clamp(42px, 5vw, 62px);
  line-height: .96;
  margin: 0 0 22px;
}
.auth-split-copy p {
  margin: 0;
  font-size: 18px;
  line-height: 1.55;
  color: rgba(255,255,255,.9);
}
.auth-split-form-wrap {
  display: grid;
  place-items: center;
  padding: 38px 24px;
  background: #f3f5fb;
}
.auth-card-split {
  width: min(470px, 100%);
}
.auth-form-header {
  text-align: center;
  margin-bottom: 26px;
}
.auth-form-header h1 {
  margin: 0 0 10px;
  font-size: 34px;
  line-height: 1.1;
  color: #1f2744;
}
.auth-form-header p {
  margin: 0;
  color: #8a94aa;
  font-size: 16px;
}
.auth-inline-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.auth-inline-link {
  color: #00d4ff;
  font-weight: 800;
  font-size: 14px;
}
.auth-primary-btn {
  width: 100%;
  min-height: 54px;
  border-radius: 10px;
  box-shadow: 0 16px 38px rgba(48, 26, 114, .18);
}
.auth-illustration {
  margin-top: auto;
  position: relative;
  min-height: 270px;
  z-index: 1;
}
.auth-illustration-screen {
  position: absolute;
  left: 82px;
  bottom: 42px;
  width: 185px;
  height: 118px;
  border-radius: 14px;
  border: 4px solid rgba(255,255,255,.9);
  background: rgba(255,255,255,.09);
  backdrop-filter: blur(8px);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.12);
}
.auth-illustration-screen span {
  display: block;
  height: 12px;
  border-radius: 10px;
  background: rgba(255,255,255,.8);
  margin-left: 24px;
}
.auth-illustration-screen span:first-child {
  width: 96px;
  margin-top: 30px;
}
.auth-illustration-screen span:last-child {
  width: 126px;
  margin-top: 14px;
}
.auth-illustration-shadow {
  position: absolute;
  left: 108px;
  bottom: 6px;
  width: 136px;
  height: 20px;
  border-radius: 10px;
  background: rgba(255,255,255,.8);
}
.auth-illustration-float {
  position: absolute;
  width: 56px;
  height: 56px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 18px 40px rgba(255,255,255,.08);
  font-size: 22px;
}
.auth-illustration-float-left { left: 28px; bottom: 68px; }
.auth-illustration-float-top { left: 210px; bottom: 148px; }
.auth-illustration-float-right { left: 290px; bottom: 58px; }
.auth-split-visual::before,
.auth-split-visual::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  filter: blur(8px);
}
.auth-split-visual::before {
  width: 96px;
  height: 96px;
  left: 26px;
  bottom: 54px;
}
.auth-split-visual::after {
  width: 74px;
  height: 74px;
  left: 458px;
  bottom: 176px;
}

.card {
  background: #fff;
  border: 1px solid #e7eaf2;
  border-radius: 14px;
  padding: 24px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .05);
}
.card + .card { margin-top: 18px; }
.grid > .card,
.grid > article.card,
.project-grid > .card,
.project-grid > article.card { margin-top: 0; }
.grid { display: grid; gap: 18px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.stats .card { padding: 18px; }
.stat-value { font-size: 40px; font-weight: 800; color: #0f172a; line-height: 1; }
.stat-label { color: #7a8396; margin-top: 8px; font-weight: 700; }
.hero {
  background: linear-gradient(180deg, rgba(var(--primary-rgb), .08), #fff);
  border: 1px solid #e7eaf2;
  color: #0f172a;
  padding: 28px;
  border-radius: 14px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .05);
}
.hero h2 { margin: 0 0 10px; font-size: 32px; }
.hero p { margin: 0; color: #64748b; max-width: 900px; }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.field.full { grid-column: 1 / -1; }
label { font-size: 14px; font-weight: 700; color: #23304a; display: block; }
input, textarea, select {
  width: 100%;
  border: 1px solid #dfe5f0;
  border-radius: 10px;
  background: #fff;
  padding: 14px 16px;
  font: inherit;
  color: #111827;
}
textarea {
  border-radius: 12px;
  min-height: 120px;
  resize: vertical;
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(var(--primary-rgb), .12);
}
.btn, .btn-secondary, .btn-small {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 10px;
  padding: 13px 18px;
  font-weight: 800;
  border: 0;
  cursor: pointer;
  font-family: inherit;
}
.btn { background: var(--blue); color: #fff; }
.btn.secondary,
.btn-secondary { background: #fff; color: #111827; border: 1px solid #dce3ef; }
.btn.success { background: #15803d; color: #fff; }
.btn.warning { background: #9a3412; color: #fff; }
.btn.danger { background: #be123c; color: #fff; }
.btn-row { display: flex; flex-wrap: wrap; gap: 10px; }
.muted { color: #7b8497; }
.alert {
  border-radius: 12px;
  padding: 15px 18px;
  margin-bottom: 16px;
  font-weight: 700;
}
.alert.success { background: #edfdf3; color: #166534; border: 1px solid #bbf7d0; }
.alert.error { background: #fff1f2; color: #be123c; border: 1px solid #fecdd3; }
.alert.info { background: #eef4ff; color: #234a8f; border: 1px solid #dbeafe; }
.badge,
.status-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 800;
}
.badge.warning, .status-pill.warning { background: #fff7ed; color: #c2410c; }
.badge.info, .status-pill.info { background: #eff6ff; color: #1d4ed8; }
.badge.success, .status-pill.success { background: #ecfdf5; color: #15803d; }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { text-align: left; padding: 16px 12px; border-bottom: 1px solid #edf1f7; vertical-align: middle; }
.table th { color: #617089; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; }
.list-stack { display: flex; flex-direction: column; gap: 16px; }
.task-note { border: 1px solid #ece7f8; border-radius: 12px; padding: 16px; background: #fcfbff; }
.task-note-header { display: flex; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.note-author { font-weight: 700; color: #00d4ff; }
.inline-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip { background: #f0ebff; color: #00d4ff; padding: 8px 12px; border-radius: 10px; font-weight: 700; font-size: 13px; }
.chrono { font-size: 32px; font-weight: 800; color: #00d4ff; }
.spacer { height: 8px; }

@media (max-width: 1080px) {
  .admin-sidebar { position: static; width: auto; height: auto; overflow: visible; }
  .admin-main { margin-left: 0; }
  .stats .grid-4,
  .grid-2, .grid-3, .grid-4, .form-grid { grid-template-columns: 1fr; }
  .auth-split-page { grid-template-columns: 1fr; }
  .auth-split-visual { min-height: 380px; }
}

@media (max-width: 640px) {
  .admin-content, .admin-topbar { padding: 18px; }
  .admin-topbar { flex-direction: column; align-items: flex-start; }
  .admin-user-dropdown { min-width: min(290px, calc(100vw - 36px)); }
  .auth-split-copy { margin-top: 48px; }
  .auth-split-copy h1 { font-size: 38px; }
  .auth-illustration { transform: scale(.88); transform-origin: left bottom; }
}


.project-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
}
.project-grid > * {
  min-width: 0;
}
.project-card {
  padding: 20px;
  border-radius: 14px;
  box-shadow: none;
  display: grid;
  grid-template-rows: auto auto auto auto;
  gap: 12px;
  align-content: start;
  height: 100%;
  min-height: 250px;
}
.project-card .project-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 0;
}
.project-card .project-title {
  margin: 0;
  min-height: 52px;
}
.project-card .project-title h3 {
  margin: 0;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -.02em;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.project-card .project-description {
  margin: 0;
  color: #7b8497;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.project-card .project-footer-meta {
  margin: 0;
}
.project-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  padding-top: 0;
}
.project-card-actions .btn {
  padding: 11px 14px;
  border-radius: 14px;
}
.project-card-actions .btn.secondary {
  background: #f8fbfd;
  border-color: #dde7ef;
}
.project-view-hero {

  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
}
.project-view-hero p { max-width: 760px; }
.task-view-shell { display:grid; grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr); gap:18px; }
.task-view-main, .task-view-side { display:grid; gap:18px; }
.task-hero {
  background: linear-gradient(180deg, rgba(var(--primary-rgb), .12), #fff);
  border: 1px solid #dff8ff;
}
.task-title-row { display:flex; justify-content:space-between; gap:16px; align-items:flex-start; flex-wrap:wrap; }
.task-title-row h1 { margin:0; font-size:32px; line-height:1.08; }
.task-meta-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:14px; }
.task-meta-box { border:1px solid #e7eef5; border-radius:18px; padding:16px; background:#fff; }
.task-meta-box strong { display:block; font-size:13px; color:#64748b; margin-bottom:8px; }
.task-section-title { margin:0 0 14px; font-size:20px; }
.attachments-grid { display:grid; gap:12px; }
.attachment-item { align-items:flex-start; }
.note-feed-form textarea { min-height: 130px; }
.task-note { background:#fff; }
.task-actions-sticky { position: sticky; top: 102px; }
.btn.info-btn { background: rgba(var(--primary-rgb), .12); color: var(--blue); border:1px solid rgba(var(--primary-rgb), .18); }
.btn.ghost { background:#f8fbfd; color:#111827; border:1px solid #dcecf2; }
@media (max-width: 1080px) {
  .project-grid { grid-template-columns: 1fr; }
  .task-view-shell { grid-template-columns: 1fr; }
  .task-actions-sticky { position: static; }
  .task-meta-grid { grid-template-columns: 1fr; }
}

.task-view-shell-full {
  display: block;
}
.task-view-shell-full .task-view-main {
  display: grid;
  gap: 18px;
}
.task-summary-card {
  display: grid;
  gap: 18px;
}
.task-header-actions-wrap {
  display: grid;
  gap: 12px;
  padding-top: 4px;
  border-top: 1px solid #edf1f7;
}
.task-header-actions {
  align-items: center;
}
.task-header-actions form {
  margin: 0;
}
.task-header-actions .btn,
.task-header-actions button.btn {
  min-height: 46px;
}
.task-header-actions-secondary {
  margin-top: 0;
}
@media (max-width: 1080px) {
  .task-view-shell-full {
    display: block;
  }
}


#project_ids {
  min-height: 220px;
}

.task-header-actions-unified {
  flex-wrap: nowrap;
  gap: 12px;
  align-items: stretch;
}
.task-header-actions-unified > .btn,
.task-header-actions-unified > a.btn,
.task-header-actions-unified > form {
  flex: 0 0 auto;
}
.task-header-actions-unified form {
  margin: 0;
}
.task-header-actions-unified .btn,
.task-header-actions-unified button.btn {
  min-height: 46px;
  font-size: 16px;
  font-weight: 700;
  white-space: nowrap;
}

@media (max-width: 1180px) {
  .task-header-actions-unified {
    flex-wrap: wrap;
  }
}


.badge,
.status-pill,
.chip,
.admin-user-trigger,
.auth-stat,
.auth-float,
.admin-avatar,
.circle,
[class*="avatar"] {
  border-radius: 999px;
}

#project_ids {
  display: none;
}

.multi-select {
  position: relative;
}
.multi-select-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid #dfe5f0;
  border-radius: 10px;
  background: #fff;
  color: #111827;
  font: inherit;
  text-align: left;
  cursor: pointer;
}
.multi-select.is-open .multi-select-trigger,
.multi-select-trigger:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(var(--primary-rgb), .12);
}
.multi-select-panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 30;
  display: none;
  background: #fff;
  border: 1px solid #dfe5f0;
  border-radius: 12px;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .08);
  padding: 12px;
}
.multi-select.is-open .multi-select-panel {
  display: block;
}
.multi-select-search-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #e5eaf3;
  border-radius: 10px;
  padding: 0 12px;
  margin-bottom: 10px;
}
.multi-select-search-wrap i {
  color: #7b8497;
}
.multi-select-search {
  border: 0;
  box-shadow: none !important;
  padding-left: 0;
  padding-right: 0;
}
.multi-select-options {
  display: grid;
  gap: 6px;
  max-height: 260px;
  overflow: auto;
}
.multi-select-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
}
.multi-select-option:hover {
  background: #f7fbfd;
}
.multi-select-option input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--blue);
}
.multi-select-option span {
  flex: 1;
  min-width: 0;
}
.multi-select-empty {
  color: #7b8497;
  padding: 10px 2px 2px;
  font-size: 14px;
}
