/* Google Fonts — must be first */
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap");

/* ================================================================
   BGI MAIL — Premium Design System
   PT. Berta Group Indonesia
   
   Brand Colors extracted from logo:
   - Navy Primary:    #1a2744
   - Navy Secondary:  #243556
   - Navy Light:      #2f4a78
   - Accent Blue:     #3d6cb5
   - Surface:         #f7f8fc
   - Card:            #ffffff
   ================================================================ */

/* ── CSS Variables ── */
:root {
  --bgi-primary: #1a2744;
  --bgi-primary-rgb: 26, 39, 68;
  --bgi-secondary: #243556;
  --bgi-primary-light: #2f4a78;
  --bgi-accent: #3d6cb5;
  --bgi-accent-light: #5a8fd4;
  --bgi-surface: #f7f8fc;
  --bgi-card: #ffffff;
  --bgi-border: #e2e6ef;
  --bgi-text: #1e293b;
  --bgi-text-secondary: #64748b;
  --bgi-text-muted: #94a3b8;
  --bgi-success: #059669;
  --bgi-danger: #dc2626;
  --bgi-warning: #d97706;
  --bgi-radius: 10px;
  --bgi-radius-sm: 6px;
  --bgi-radius-lg: 16px;
  --bgi-radius-xl: 24px;
  --bgi-shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --bgi-shadow: 0 4px 12px rgba(0,0,0,0.08);
  --bgi-shadow-lg: 0 10px 40px rgba(0,0,0,0.12);
  --bgi-shadow-xl: 0 20px 60px rgba(0,0,0,0.15);
  --bgi-transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --bgi-font: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

/* ── Global Reset ── */
body {
  font-family: var(--bgi-font) !important;
  background: var(--bgi-surface) !important;
  color: var(--bgi-text) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ================================================================
   LOGIN PAGE — Premium White SaaS Design
   ================================================================ */

body.task-login {
  background: #fafbfc !important;
  min-height: 100vh;
}

/* Override Elastic base — MUST use higher specificity */
body.task-login #layout {
  display: flex !important;
  min-height: 100vh !important;
  padding: 0 !important;
}

body.task-login #layout-content,
.task-login #layout-content {
  background: transparent !important;
  display: flex !important;
  flex: 1 !important;
  min-height: 100vh !important;
  padding: 0 !important;
  max-width: none !important;
  width: 100% !important;
  text-align: left !important;
  position: static !important;
}

/* Kill Elastic login-form positioning */
body.task-login #login-form,
.task-login #login-form {
  position: static !important;
  top: auto !important;
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
}

/* Kill Elastic #logo */
body.task-login #logo,
.task-login #logo {
  display: none !important;
}

/* ── Two-column Layout ── */
.bgi-login-wrapper {
  display: flex;
  width: 100%;
  min-height: 100vh;
}

/* Left: Form Side */
.bgi-login-left {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 40px;
  background: #ffffff;
  position: relative;
}

/* Right: Brand Side */
.bgi-login-right {
  flex: 0 0 44%;
  background: linear-gradient(160deg, #1a2744 0%, #243556 50%, #2f4a78 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px;
  position: relative;
  overflow: hidden;
}

.bgi-login-right::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -30%;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: rgba(61,108,181,0.08);
}

.bgi-login-right::after {
  content: "";
  position: absolute;
  bottom: -30%;
  left: -20%;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: rgba(90,143,212,0.06);
}

/* ── Login Card ── */
.bgi-login-card {
  width: 100%;
  max-width: 400px;
  animation: bgiSlideUp 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes bgiSlideUp {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Header: Logo + Brand ── */
.bgi-login-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
}

.bgi-login-logo {
  width: 44px;
  height: 44px;
  object-fit: contain;
}

.bgi-login-titles {
  display: flex;
  flex-direction: column;
}

.bgi-login-title {
  font-size: 21px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  margin: 0 !important;
  letter-spacing: -0.4px;
  line-height: 1.2;
}

.bgi-login-subtitle {
  font-size: 12px !important;
  color: #64748b !important;
  margin: 3px 0 0 !important;
  font-weight: 500;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

.bgi-login-divider {
  height: 1px;
  background: #e5e7eb;
  margin-bottom: 36px;
}

/* ── Heading ── */
.bgi-login-heading {
  font-size: 26px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  margin: 0 0 8px !important;
  letter-spacing: -0.5px;
  line-height: 1.25;
}

.bgi-login-desc {
  font-size: 15px !important;
  color: #64748b !important;
  margin: 0 0 32px !important;
  line-height: 1.5;
  font-weight: 400;
}

/* ── Login Form Container ── */
body.task-login #login-form,
.bgi-login-form {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: none !important;
  width: 100% !important;
  position: static !important;
  top: auto !important;
}

/* ── Form table → stacked ── */
body.task-login #login-form table,
body.task-login #login-form tbody {
  display: block !important;
  width: 100% !important;
  border: none !important;
}

body.task-login #login-form table tr,
body.task-login #login-form table tr.form-group {
  display: block !important;
  width: 100% !important;
  background: none !important;
  border: none !important;
  margin-bottom: 20px !important;
  padding: 0 !important;
}

body.task-login #login-form table td {
  display: block !important;
  width: 100% !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

/* ── Elastic JS hides labels & wraps in input-group — undo that ── */
body.task-login #login-form .input-group {
  display: block !important;
  position: relative !important;
}

body.task-login #login-form .input-group-prepend,
body.task-login #login-form .input-group-text,
body.task-login #login-form .input-group > i {
  display: none !important;
}

/* ── Inputs (after JS adds input-group-lg) ── */
body.task-login .form-control,
body.task-login .input-group-lg > .form-control,
body.task-login input#rcmloginuser,
body.task-login input#rcmloginpwd {
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 12px !important;
  padding: 0 16px !important;
  height: 48px !important;
  font-size: 15px !important;
  font-family: var(--bgi-font) !important;
  background: #f8fafc !important;
  color: #1f2937 !important;
  transition: var(--bgi-transition) !important;
  width: 100% !important;
  display: block !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  line-height: 48px !important;
}

body.task-login .form-control:focus,
body.task-login input#rcmloginuser:focus,
body.task-login input#rcmloginpwd:focus {
  border-color: #1a2744 !important;
  box-shadow: 0 0 0 3px rgba(26,39,68,0.10) !important;
  background: #ffffff !important;
  outline: none !important;
}

body.task-login .form-control::placeholder {
  color: #9ca3af !important;
  font-weight: 400 !important;
}

/* ── Submit Button ── */
body.task-login .formbuttons {
  margin-top: 12px !important;
  padding: 0 !important;
}

body.task-login #rcmloginsubmit,
body.task-login .formbuttons .button.submit,
body.task-login button.mainaction {
  background: #1a2744 !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 0 24px !important;
  height: 48px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  font-family: var(--bgi-font) !important;
  letter-spacing: 0.3px;
  color: #fff !important;
  cursor: pointer;
  transition: var(--bgi-transition) !important;
  box-shadow: 0 1px 2px rgba(26,39,68,0.08), 0 2px 8px rgba(26,39,68,0.10) !important;
  text-transform: none !important;
  width: 100% !important;
  display: block !important;
  margin: 0 !important;
  line-height: 48px !important;
  text-align: center !important;
}

body.task-login #rcmloginsubmit:hover,
body.task-login button.mainaction:hover {
  background: #0f172a !important;
  box-shadow: 0 2px 4px rgba(26,39,68,0.12), 0 4px 16px rgba(26,39,68,0.10) !important;
  transform: translateY(-1px);
}

body.task-login #rcmloginsubmit:active,
body.task-login button.mainaction:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(26,39,68,0.1) !important;
}

/* ── Hide host field ── */
body.task-login #rcmloginhost {
  display: none !important;
}

/* ── Hide message stack overlay on login ── */
body.task-login #messagestack {
  z-index: 10000 !important;
}

/* ── Footer ── */
.bgi-login-footer {
  margin-top: 32px;
  padding-top: 22px;
  border-top: 1px solid #e5e7eb;
}

.bgi-login-secure {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-size: 13px;
  color: #64748b;
  font-weight: 500;
}

.bgi-login-secure svg {
  color: var(--bgi-success);
  flex-shrink: 0;
}

.bgi-login-copyright {
  position: absolute;
  bottom: 28px;
  font-size: 12px;
  color: #94a3b8;
  letter-spacing: 0.2px;
  font-weight: 400;
}

/* ── Right Panel: Brand ── */
.bgi-login-brand {
  text-align: left;
  max-width: 340px;
  position: relative;
  z-index: 1;
}

.bgi-login-brand-logo {
  width: 64px;
  height: 64px;
  object-fit: contain;
  margin-bottom: 28px;
  opacity: 0.9;
}

.bgi-login-brand-title {
  font-size: 36px !important;
  font-weight: 700 !important;
  color: #ffffff !important;
  margin: 0 0 16px !important;
  line-height: 1.2;
  letter-spacing: -0.5px;
}

.bgi-login-brand-tagline {
  font-size: 16px !important;
  color: rgba(255,255,255,0.6) !important;
  margin: 0 0 40px !important;
  line-height: 1.5;
}

.bgi-login-features {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.bgi-login-feature {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: rgba(255,255,255,0.8);
}

.bgi-login-feature svg {
  color: rgba(255,255,255,0.5);
  flex-shrink: 0;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .bgi-login-wrapper {
    flex-direction: column-reverse;
  }

  .bgi-login-right {
    flex: none;
    padding: 40px 32px;
    min-height: auto;
  }

  .bgi-login-right::before,
  .bgi-login-right::after {
    display: none;
  }

  .bgi-login-brand-title {
    font-size: 24px !important;
  }

  .bgi-login-brand-tagline {
    margin-bottom: 24px !important;
  }

  .bgi-login-features {
    display: none;
  }

  .bgi-login-left {
    padding: 32px 24px;
  }

  .bgi-login-copyright {
    position: relative;
    bottom: auto;
    margin-top: 32px;
  }
}

@media (max-width: 480px) {
  .bgi-login-right {
    padding: 28px 24px;
  }

  .bgi-login-brand-logo {
    width: 40px;
    height: 40px;
    margin-bottom: 16px;
  }

  .bgi-login-brand-title {
    font-size: 20px !important;
  }

  .bgi-login-heading {
    font-size: 20px !important;
  }
}

/* ================================================================
   APP LAYOUT — Premium SaaS Webmail
   ================================================================ */

/* ── Global Layout ── */
#layout {
  background: #f1f5f9 !important;
  overflow: hidden !important;
}

/* ── Sidebar / Task Menu ── */
#layout-menu {
  background: #0f172a !important;
  border-right: none !important;
  width: 72px !important;
  min-width: 72px !important;
}

#layout-menu .popover-header {
  background: transparent !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  padding: 14px 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 56px !important;
}

/* Force show logo link (Elastic hides it on desktop by default) */
#layout-menu .popover-header a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
}

/* Hide close button in sidebar header on desktop */
#layout-menu .popover-header a.button.cancel {
  display: none !important;
}

/* Hide logo text in sidebar header, keep icon only */
#layout-menu .popover-header a span {
  display: none !important;
}

#layout-menu .popover-header a img {
  display: block !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 8px !important;
}

#taskmenu {
  background: transparent !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 6px 0 !important;
  flex: 1 !important;
}

#taskmenu a {
  color: rgba(255,255,255,0.5) !important;
  border-radius: 10px !important;
  margin: 1px 8px !important;
  padding: 8px 0 !important;
  transition: all 0.15s ease !important;
  text-align: center !important;
  font-size: 10px !important;
  letter-spacing: 0.3px !important;
  width: auto !important;
  height: auto !important;
  line-height: 1.2 !important;
}

/* Icon sizing in sidebar */
@media screen and (min-width: 481px) {
  #taskmenu a {
    width: auto !important;
    min-width: unset !important;
  }
  #taskmenu a::before {
    float: none !important;
    display: block !important;
    font-size: 18px !important;
    margin-bottom: 3px !important;
    line-height: 1.2 !important;
  }
  #taskmenu span.inner {
    display: block !important;
    font-size: 10px !important;
    padding: 0 2px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
}

#taskmenu a:hover {
  background: rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.9) !important;
}

#taskmenu a.selected {
  background: rgba(255,255,255,0.12) !important;
  color: #fff !important;
  font-weight: 600 !important;
}

#taskmenu a::before {
  color: inherit !important;
  opacity: 0.8;
  transition: all 0.15s ease !important;
}

#taskmenu a:hover::before,
#taskmenu a.selected::before {
  color: #fff !important;
  opacity: 1;
}

#taskmenu .special-buttons {
  border-top: 1px solid rgba(255,255,255,0.06) !important;
  margin-top: auto !important;
  padding-top: 6px !important;
}

/* Logout button red */
#taskmenu a.logout {
  color: rgba(239,68,68,0.7) !important;
}
#taskmenu a.logout:hover {
  color: #ef4444 !important;
  background: rgba(239,68,68,0.1) !important;
}

/* ── Compose FAB ── */
#taskmenu a.compose,
.floating-action-buttons a.compose {
  background: #3b82f6 !important;
  color: #fff !important;
  border-radius: 12px !important;
  margin: 6px 8px 10px !important;
  padding: 10px 0 !important;
  box-shadow: 0 2px 8px rgba(59,130,246,0.35) !important;
  transition: all 0.15s ease !important;
}

#taskmenu a.compose:hover,
.floating-action-buttons a.compose:hover {
  background: #2563eb !important;
  box-shadow: 0 4px 14px rgba(59,130,246,0.45) !important;
  transform: translateY(-1px);
}

#taskmenu a.compose::before,
.floating-action-buttons a.compose::before {
  color: #fff !important;
}

/* ── Folder Sidebar Panel (mail task only) ── */
body.task-mail #layout-sidebar {
  background: #ffffff !important;
  border-right: 1px solid #e2e8f0 !important;
  min-width: 220px !important;
}

body.task-mail #layout-sidebar > .header {
  background: #ffffff !important;
  border-bottom: 1px solid #f1f5f9 !important;
  box-shadow: none !important;
  padding: 10px 16px !important;
  min-height: 48px !important;
}

body.task-mail #layout-sidebar .header .header-title {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  text-align: left !important;
  margin: 0 !important;
}

/* Username in sidebar header - truncate nicely */
body.task-mail #layout-sidebar .header .header-title.username {
  font-size: 12px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: #475569 !important;
  font-weight: 500 !important;
  max-width: 180px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.task-mail #layout-sidebar .scroller {
  padding: 8px 10px !important;
}

body.task-mail #layout-sidebar .footer {
  background: #fafbfc !important;
  border-top: 1px solid #f1f5f9 !important;
  padding: 10px 16px !important;
  font-size: 11px !important;
  color: #94a3b8 !important;
}

/* ── Folder List ── */
#mailboxlist {
  padding: 0 !important;
}

#mailboxlist li {
  margin-bottom: 1px !important;
}

#mailboxlist li a {
  border-radius: 8px !important;
  padding: 9px 12px !important;
  transition: all 0.12s ease !important;
  color: #334155 !important;
  font-size: 13.5px !important;
  font-weight: 450 !important;
  line-height: 1.3 !important;
}

#mailboxlist li a:hover {
  background: #f1f5f9 !important;
  color: #1e293b !important;
}

#mailboxlist li a.selected,
#mailboxlist li.selected > a {
  background: #eff6ff !important;
  color: #1d4ed8 !important;
  font-weight: 600 !important;
}

#mailboxlist li a.selected::before,
#mailboxlist li.selected > a::before {
  color: #3b82f6 !important;
}

#mailboxlist .unreadcount {
  background: #3b82f6 !important;
  color: #fff !important;
  border-radius: 10px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  padding: 1px 7px !important;
  min-width: 18px;
  text-align: center;
  line-height: 18px !important;
}

/* ── Quota Widget ── */
.quota-widget {
  font-size: 11px !important;
  color: #94a3b8 !important;
}

.quota-widget .bar {
  background: #e2e8f0 !important;
  border-radius: 4px !important;
  height: 4px !important;
  overflow: hidden !important;
}

.quota-widget .bar .value {
  background: #3b82f6 !important;
  border-radius: 4px !important;
}

/* ── Message List Panel ── */
#layout-list {
  background: #ffffff !important;
  border-right: 1px solid #e2e8f0 !important;
}

#layout-list > .header,
#messagelist-header {
  background: #ffffff !important;
  border-bottom: 1px solid #f1f5f9 !important;
  box-shadow: none !important;
  min-height: 44px !important;
  padding: 4px 8px !important;
}

/* ── Search Bar ── */
.searchbar {
  background: #ffffff !important;
  border-bottom: 1px solid #f1f5f9 !important;
  padding: 8px 12px !important;
}

.searchbar input,
#quicksearchbar input,
.searchbar .form-control {
  border-radius: 10px !important;
  padding: 9px 14px 9px 36px !important;
  background: #f1f5f9 !important;
  border: 1.5px solid transparent !important;
  font-size: 13px !important;
  color: #334155 !important;
  height: 38px !important;
  font-family: var(--bgi-font) !important;
}

.searchbar input:focus,
#quicksearchbar input:focus,
.searchbar .form-control:focus {
  background: #fff !important;
  border-color: #3b82f6 !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,0.08) !important;
  outline: none !important;
}

.searchbar input::placeholder {
  color: #94a3b8 !important;
}

/* ── Toolbar (message list header actions) ── */
.toolbar a.button,
.toolbar a {
  border-radius: 8px !important;
  transition: all 0.12s ease !important;
  margin: 2px !important;
  color: #64748b !important;
}

.toolbar a.button:hover,
.toolbar a:hover {
  background: #f1f5f9 !important;
  color: #334155 !important;
}

.toolbar a.button::before,
.toolbar a::before {
  color: #94a3b8 !important;
  transition: all 0.12s ease !important;
}

.toolbar a.button:hover::before,
.toolbar a:hover::before {
  color: #334155 !important;
}

/* Disabled toolbar buttons */
.toolbar a.disabled,
.toolbar a.button.disabled {
  color: #cbd5e1 !important;
  opacity: 0.5 !important;
  cursor: default !important;
}

.toolbar a.disabled::before,
.toolbar a.button.disabled::before {
  color: #cbd5e1 !important;
}

/* Toolbar labels */
.toolbar a .inner {
  font-size: 11px !important;
  font-weight: 500 !important;
  color: inherit !important;
}

/* ── Message List ── */
#messagelist,
.messagelist {
  background: #ffffff !important;
}

#messagelist thead tr,
.messagelist thead tr {
  background: #fafbfc !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

#messagelist thead th,
.messagelist thead th {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #94a3b8 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  padding: 10px 12px !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

#messagelist tr,
.messagelist tr {
  border-bottom: 1px solid #f8fafc !important;
  transition: background 0.1s ease !important;
}

#messagelist tr td,
.messagelist tr td {
  padding: 12px !important;
  font-size: 13.5px !important;
  color: #475569 !important;
  vertical-align: middle !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

#messagelist tr:hover,
.messagelist tr:hover {
  background: #f8fafc !important;
}

#messagelist tr.selected td,
.messagelist tr.selected td {
  background: #eff6ff !important;
  border-left-color: #3b82f6 !important;
}

#messagelist tr.focused td {
  box-shadow: inset 0 0 0 1px rgba(59,130,246,0.2) !important;
}

#messagelist tr.unread td {
  font-weight: 500 !important;
  color: #0f172a !important;
}

#messagelist tr.unread td.subject span,
.messagelist tr.unread td.subject span {
  font-weight: 600 !important;
  color: #0f172a !important;
}

#messagelist tr td.subject {
  color: #1e293b !important;
  font-weight: 450 !important;
}

#messagelist tr td.date,
#messagelist tr td.size {
  font-size: 12px !important;
  color: #94a3b8 !important;
  white-space: nowrap !important;
}

/* Message flags */
#messagelist tr td.flag .icon {
  opacity: 0.5 !important;
}

#messagelist tr td.flag .icon.flagged {
  opacity: 1 !important;
  color: #f59e0b !important;
}

/* ── Content / Reading Pane (not login) ── */
body:not(.task-login) #layout-content {
  background: #f8fafc !important;
}

body.task-mail #layout-content > .header {
  background: #ffffff !important;
  border-bottom: 1px solid #e2e8f0 !important;
  box-shadow: none !important;
  min-height: 44px !important;
  padding: 4px 8px !important;
}

body.task-mail #layout-content .iframe-wrapper {
  background: #f8fafc !important;
}

/* ── Page Navigation ── */
.pagenav,
#layout-list > .footer {
  background: #fafbfc !important;
  border-top: 1px solid #f1f5f9 !important;
  padding: 0 12px !important;
  font-size: 11px !important;
  color: #94a3b8 !important;
  height: 36px !important;
  min-height: 36px !important;
  line-height: 36px !important;
}

.pagenav a {
  color: #94a3b8 !important;
  border-radius: 6px !important;
  padding: 4px 6px !important;
  font-size: 11px !important;
}

.pagenav a:hover {
  background: #f1f5f9 !important;
  color: #334155 !important;
}

/* Pagenav input */
.pagenav input {
  width: 36px !important;
  height: 24px !important;
  text-align: center !important;
  font-size: 11px !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 6px !important;
  padding: 2px 4px !important;
}

/* "Mailbox is empty" text in footer */
.pagenav .listinfo,
#layout-list .footer .listinfo {
  font-size: 11px !important;
  color: #94a3b8 !important;
  font-weight: 400 !important;
}

/* ── Cards & Panels ── */
.boxcontent,
.propform,
.uibox {
  border-radius: 12px !important;
}

/* ── Buttons Global ── */
.btn,
.button,
a.button {
  border-radius: 8px !important;
  font-family: var(--bgi-font) !important;
  font-weight: 500 !important;
  transition: all 0.15s ease !important;
  font-size: 13px !important;
}

.btn-primary,
.formbuttons .button.submit,
.formbuttons .button.create {
  background: #1a2744 !important;
  border-color: #1a2744 !important;
  color: #fff !important;
  box-shadow: 0 1px 3px rgba(26,39,68,0.15) !important;
}

.btn-primary:hover,
.formbuttons .button.submit:hover {
  background: #0f172a !important;
  border-color: #0f172a !important;
  box-shadow: 0 2px 8px rgba(26,39,68,0.25) !important;
  transform: translateY(-1px);
}

.btn-secondary,
.formbuttons .button.cancel {
  background: #fff !important;
  border: 1.5px solid #e2e8f0 !important;
  color: #334155 !important;
}

.btn-secondary:hover,
.formbuttons .button.cancel:hover {
  background: #f8fafc !important;
  border-color: #cbd5e1 !important;
}

.btn-danger,
.formbuttons .button.delete {
  background: #ef4444 !important;
  border-color: #ef4444 !important;
  color: #fff !important;
}

.btn-danger:hover,
.formbuttons .button.delete:hover {
  background: #dc2626 !important;
}

/* ── Form Controls (settings pages only, avoid compose) ── */
body.task-settings .form-control,
body.task-settings input[type="text"],
body.task-settings input[type="password"],
body.task-settings select,
body.task-settings textarea {
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 8px !important;
  padding: 9px 12px !important;
  font-family: var(--bgi-font) !important;
  font-size: 13.5px !important;
  transition: all 0.15s ease !important;
  color: #1e293b !important;
  background: #fff !important;
}

body.task-settings .form-control:focus,
body.task-settings input:focus,
body.task-settings select:focus,
body.task-settings textarea:focus {
  border-color: #3b82f6 !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,0.08) !important;
  outline: none !important;
}

/* ── Dialogs / Modals ── */
.ui-dialog {
  border-radius: 14px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.04) !important;
  border: none !important;
  overflow: hidden;
}

.ui-dialog .ui-dialog-titlebar {
  background: #fff !important;
  border-bottom: 1px solid #f1f5f9 !important;
  padding: 18px 22px !important;
  font-family: var(--bgi-font) !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  color: #0f172a !important;
}

.ui-dialog .ui-dialog-content {
  padding: 22px !important;
  font-family: var(--bgi-font) !important;
  color: #334155 !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
}

.ui-dialog .ui-dialog-buttonpane {
  background: #fafbfc !important;
  border-top: 1px solid #f1f5f9 !important;
  padding: 14px 22px !important;
}

/* ── Dropdowns / Popups ── */
.popupmenu,
.dropdown-menu,
.menu.popup {
  border-radius: 12px !important;
  box-shadow: 0 10px 40px rgba(0,0,0,0.10), 0 0 0 1px rgba(0,0,0,0.04) !important;
  border: none !important;
  padding: 6px !important;
  background: #fff !important;
}

.popupmenu li a,
.dropdown-menu a,
.menu.popup a {
  border-radius: 8px !important;
  padding: 9px 14px !important;
  transition: all 0.1s ease !important;
  font-size: 13px !important;
  color: #334155 !important;
}

.popupmenu li a:hover,
.dropdown-menu a:hover,
.menu.popup a:hover {
  background: #f1f5f9 !important;
  color: #0f172a !important;
}

.popupmenu li a::before,
.dropdown-menu a::before {
  color: #64748b !important;
}

/* ── Notifications / Toast ── */
#messagestack {
  z-index: 10000 !important;
}

#messagestack div {
  border-radius: 10px !important;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12) !important;
  font-family: var(--bgi-font) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 14px 22px !important;
  border: none !important;
}

#messagestack .notice {
  background: #0f172a !important;
  color: #fff !important;
}

#messagestack .confirmation {
  background: #059669 !important;
  color: #fff !important;
}

#messagestack .error,
#messagestack .warning {
  background: #ef4444 !important;
  color: #fff !important;
}

/* ── Loading Spinner ── */
.loading::after,
.loading::before {
  border-color: #3b82f6 transparent transparent !important;
}

/* ── Scrollbar ── */
::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
  background: #94a3b8;
}

/* ── Links (content area only) ── */
#layout-content a:not(.button):not(.btn) {
  color: #3b82f6 !important;
  transition: color 0.12s ease !important;
}

#layout-content a:not(.button):not(.btn):hover {
  color: #1d4ed8 !important;
}

/* ── Checkbox ── */
input[type="checkbox"] {
  accent-color: #3b82f6 !important;
}

/* ── Compose Window ── */
#composebody,
.mce-content-body {
  font-family: var(--bgi-font) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  color: #1e293b !important;
}

/* ── Compose Headers (From, To, Subject) ── */
#compose-content .compose-headers {
  background: #fff !important;
  padding: 8px 12px !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

#compose-content .compose-headers .form-group {
  margin-bottom: 2px !important;
  padding: 4px 0 !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

#compose-content .compose-headers .form-group:last-child {
  border-bottom: none !important;
}

#compose-content .compose-headers label {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: #64748b !important;
  min-width: 55px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
}

#compose-content .compose-headers input.form-control,
#compose-content .compose-headers .input-group input {
  border: none !important;
  border-radius: 0 !important;
  padding: 6px 8px !important;
  font-size: 14px !important;
  color: #1e293b !important;
  background: transparent !important;
  box-shadow: none !important;
}

#compose-content .compose-headers input.form-control:focus,
#compose-content .compose-headers .input-group input:focus {
  box-shadow: none !important;
  outline: none !important;
}

/* Subject field slightly bolder */
#compose-content #compose-subject {
  font-weight: 500 !important;
  font-size: 15px !important;
}

/* Compose toolbar */
#compose-content > .header {
  background: #fff !important;
  border-bottom: 1px solid #e2e8f0 !important;
  padding: 0 12px !important;
}

/* Compose editor area */
#compose-content .editor-area,
#composebodycontainer {
  background: #fff !important;
}

/* Compose sidebar (attachments) */
body.action-compose #layout-sidebar {
  background: #fafbfc !important;
  border-left: 1px solid #e2e8f0 !important;
}

body.action-compose #layout-sidebar .header {
  background: #fafbfc !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

/* Attachment list */
#attachment-list li {
  padding: 8px 12px !important;
  border-bottom: 1px solid #f1f5f9 !important;
  font-size: 13px !important;
}

#attachment-list li a.filename {
  color: #334155 !important;
}

#attachment-list li .attachment-size {
  color: #94a3b8 !important;
  font-size: 11px !important;
}

/* Upload button */
.file-upload .btn,
.file-upload button.attach {
  background: #f1f5f9 !important;
  color: #334155 !important;
  border: 1.5px dashed #cbd5e1 !important;
  border-radius: 8px !important;
  font-size: 13px !important;
}

.file-upload .btn:hover,
.file-upload button.attach:hover {
  background: #e2e8f0 !important;
  border-color: #94a3b8 !important;
}

/* ── Message View / Reading Pane ── */
#message-header {
  background: #fff !important;
  padding: 16px 20px !important;
  border-bottom: 1px solid #e2e8f0 !important;
}

#message-header .header-title {
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #0f172a !important;
  line-height: 1.4 !important;
  margin-bottom: 8px !important;
}

.message-partheaders .header-title {
  font-size: 16px !important;
}

/* Message header fields (from, to, date) */
#message-header .header-content span.header-label,
.message-partheaders td.header-title {
  font-size: 12px !important;
  color: #94a3b8 !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
}

#message-header .header-content span.header-value {
  font-size: 13px !important;
  color: #334155 !important;
}

/* Message body iframe */
#messagebody {
  padding: 0 !important;
}

/* ── Addressbook / Contacts ── */
body.task-addressbook #layout-sidebar {
  background: #fff !important;
  border-right: 1px solid #e2e8f0 !important;
}

body.task-addressbook #layout-sidebar .header {
  background: #fff !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

/* Contact list */
.contactlist .contact,
#contacts-table tr td {
  padding: 10px 14px !important;
  border-bottom: 1px solid #f1f5f9 !important;
  font-size: 13.5px !important;
  color: #334155 !important;
}

.contactlist .contact:hover,
#contacts-table tr:hover td {
  background: #f8fafc !important;
}

.contactlist .contact.selected,
#contacts-table tr.selected td {
  background: #eff6ff !important;
  color: #1d4ed8 !important;
}

/* Contact detail */
#contact-frame .row-header {
  font-size: 12px !important;
  color: #94a3b8 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
}

/* Contact photo placeholder */
.contact-photo {
  border-radius: 50% !important;
  background: #f1f5f9 !important;
  border: 2px solid #e2e8f0 !important;
}

/* ── Settings Page Polish ── */
body.task-settings #layout-sidebar {
  background: #fff !important;
  border-right: 1px solid #e2e8f0 !important;
}

body.task-settings #layout-sidebar .header {
  background: #fff !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

/* Settings sections list */
#sections-table tr td a,
.listing.iconized li a {
  padding: 12px 16px !important;
  font-size: 13.5px !important;
  color: #334155 !important;
  border-radius: 8px !important;
}

#sections-table tr td a:hover,
.listing.iconized li a:hover {
  background: #f1f5f9 !important;
}

#sections-table tr.selected td a,
.listing.iconized li.selected a {
  background: #eff6ff !important;
  color: #1d4ed8 !important;
  font-weight: 500 !important;
}

/* Settings content area */
body.task-settings #layout-content {
  background: #f8fafc !important;
}

body.task-settings .formcontent {
  padding: 16px !important;
}

body.task-settings .form-group label {
  font-size: 13px !important;
  color: #475569 !important;
  font-weight: 500 !important;
}

/* Identities list */
#identities-table td {
  padding: 12px 16px !important;
}

/* ── Responsive Compose ── */
@media (max-width: 1024px) {
  #compose-content .compose-headers label {
    font-size: 11px !important;
    min-width: 45px !important;
  }
}

/* ── Responsive Sidebar collapse ── */
@media (max-width: 480px) {
  #layout-menu {
    width: 60px !important;
    min-width: 60px !important;
  }
  
  #taskmenu a {
    font-size: 9px !important;
    padding: 6px 0 !important;
  }
  
  #taskmenu a::before {
    font-size: 16px !important;
  }
  
  #taskmenu span.inner {
    display: none !important;
  }
}

/* ── Smooth transitions for panels ── */
#layout-sidebar,
#layout-list,
#layout-content {
  transition: width 0.2s ease, min-width 0.2s ease !important;
}

/* ── About Dialog ── */
.about-content .logo {
  display: none !important;
}

/* ── Selection ── */
::selection {
  background: rgba(59,130,246,0.15);
  color: #0f172a;
}

/* ── Settings page ── */
#sections-table td,
.preferences-table td {
  padding: 12px 16px !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

#sections-table tr:hover td,
.preferences-table tr:hover td {
  background: #f8fafc !important;
}

/* ── Empty list state ── */
.listing .message:first-child,
#messagelist-content .listing td,
.messagelist td[colspan] {
  color: #94a3b8 !important;
  font-style: normal !important;
  font-size: 13px !important;
  font-weight: 400 !important;
}

/* "The list is empty" centered text */
#messagelist-content .scroller {
  display: flex !important;
  flex-direction: column !important;
}

/* Empty state in message list */
.listing.messagelist tbody:empty + .message,
.listing .message.nomessages {
  text-align: center !important;
  padding: 60px 20px !important;
  color: #94a3b8 !important;
  font-size: 13px !important;
}

/* ── Header title in panels ── */
.header-title {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #1e293b !important;
  letter-spacing: -0.1px !important;
}

/* ── Listbox headers (mail task only) ── */
body.task-mail #layout > div > .header {
  background: #fff !important;
  border-bottom: 1px solid #f1f5f9 !important;
  height: auto !important;
  min-height: 44px !important;
  line-height: normal !important;
}

/* ── Header buttons (back, sidebar toggle) ── */
.header a.button.back-list-button,
.header a.button.back-sidebar-button,
.header a.button.task-menu-button {
  color: #64748b !important;
}

.header a.button.back-list-button::before,
.header a.button.back-sidebar-button::before,
.header a.button.task-menu-button::before {
  color: #64748b !important;
}

/* ── Refresh button ── */
.header a.button.refresh {
  color: #64748b !important;
}
.header a.button.refresh::before {
  color: #64748b !important;
}
.header a.button.refresh:hover {
  color: #334155 !important;
  background: #f1f5f9 !important;
}
.header a.button.refresh:hover::before {
  color: #334155 !important;
}

/* ── Fix overall body for logged-in ── */
body:not(.task-login) {
  background: #f1f5f9 !important;
}

/* ── Responsive App ── */
@media (max-width: 768px) {
  #layout-menu {
    width: 100% !important;
    min-width: 100% !important;
  }

  #layout-sidebar {
    min-width: 100% !important;
  }
}

/* ================================================================
   DARK MODE
   ================================================================ */

html.dark-mode {
  --bgi-surface: #0c1222;
  --bgi-card: #1e293b;
  --bgi-border: #1e293b;
  --bgi-text: #e2e8f0;
  --bgi-text-secondary: #94a3b8;
  --bgi-text-muted: #64748b;
}

html.dark-mode body:not(.task-login) {
  background: #0c1222 !important;
}

html.dark-mode #layout {
  background: #0c1222 !important;
}

html.dark-mode #layout-sidebar,
html.dark-mode #layout-list {
  background: #111827 !important;
  border-color: #1e293b !important;
}

html.dark-mode #layout-content {
  background: #0c1222 !important;
}

html.dark-mode #layout-content > .header,
html.dark-mode #layout-sidebar > .header,
html.dark-mode #layout-list > .header,
html.dark-mode #messagelist-header {
  background: #111827 !important;
  border-color: #1e293b !important;
}

html.dark-mode #messagelist tr td,
html.dark-mode .messagelist tr td {
  color: #94a3b8 !important;
  border-color: #1e293b !important;
}

html.dark-mode #messagelist tr:hover {
  background: rgba(255,255,255,0.02) !important;
}

html.dark-mode #messagelist tr.selected td {
  background: rgba(59,130,246,0.08) !important;
}

html.dark-mode #messagelist tr.unread td,
html.dark-mode #messagelist tr.unread td.subject span {
  color: #e2e8f0 !important;
}

html.dark-mode #messagelist thead tr {
  background: #0f172a !important;
}

html.dark-mode #messagelist thead th {
  color: #475569 !important;
  border-color: #1e293b !important;
}

html.dark-mode #mailboxlist li a {
  color: #94a3b8 !important;
}

html.dark-mode #mailboxlist li a:hover {
  background: rgba(255,255,255,0.04) !important;
  color: #e2e8f0 !important;
}

html.dark-mode #mailboxlist li a.selected,
html.dark-mode #mailboxlist li.selected > a {
  background: rgba(59,130,246,0.1) !important;
  color: #60a5fa !important;
}

html.dark-mode .form-control,
html.dark-mode input[type="text"],
html.dark-mode input[type="password"],
html.dark-mode select,
html.dark-mode textarea {
  background: #0f172a !important;
  border-color: #1e293b !important;
  color: #e2e8f0 !important;
}

html.dark-mode .searchbar input,
html.dark-mode .searchbar .form-control {
  background: #0f172a !important;
  color: #e2e8f0 !important;
}

html.dark-mode .header-title {
  color: #e2e8f0 !important;
}

html.dark-mode .ui-dialog {
  background: #1e293b !important;
}

html.dark-mode .ui-dialog .ui-dialog-titlebar {
  background: #1e293b !important;
  border-color: #334155 !important;
  color: #e2e8f0 !important;
}

html.dark-mode .popupmenu,
html.dark-mode .dropdown-menu {
  background: #1e293b !important;
  box-shadow: 0 10px 40px rgba(0,0,0,0.3) !important;
}

html.dark-mode .popupmenu li a,
html.dark-mode .dropdown-menu a {
  color: #cbd5e1 !important;
}

html.dark-mode .popupmenu li a:hover,
html.dark-mode .dropdown-menu a:hover {
  background: rgba(255,255,255,0.05) !important;
  color: #fff !important;
}

html.dark-mode ::-webkit-scrollbar-thumb {
  background: #334155;
}

html.dark-mode .pagenav {
  background: #111827 !important;
  border-color: #1e293b !important;
}

html.dark-mode #layout-sidebar .footer {
  background: #0f172a !important;
  border-color: #1e293b !important;
}
