@import url('../../elastic/styles/styles.min.css');
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&display=swap');


/* --- 2026 Modern Office Skin Design System --- */
:root {
  --primary-color: #595E46;        /* Elegant Dark Olive from Mockup */
  --primary-hover: #474B38;
  --bg-page: #EAE8E1;              /* Warm beige page background */
  --bg-column: #FFFFFF;            /* Card background */
  --text-main: #2D311B;            /* Dark olive charcoal */
  --text-muted: #8A8D80;
  --border-color: rgba(89, 94, 70, 0.12); /* Soft olive border */
  
  --radius-lg: 24px;               /* Main card panels / bo góc tròn */
  --radius-md: 12px;               /* Inputs, buttons */
  --radius-sm: 8px;                
  
  --shadow-sm: 0 2px 8px -1px rgba(89, 94, 70, 0.05);
  --shadow-md: 0 20px 40px -10px rgba(89, 94, 70, 0.12), 0 2px 8px -2px rgba(89, 94, 70, 0.05);
  --shadow-hover: 0 12px 28px -5px rgba(89, 94, 70, 0.25);
  
  --transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* --- Global Typography & Font Overrides --- */
body, 
.skin-elastic, 
.form-control, 
.btn, 
.listitem {
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  color: var(--text-main);
  -webkit-font-smoothing: antialiased;
}

body,
.skin-elastic {
  background: radial-gradient(circle at 0% 0%, #F5F4F0 0%, #EAE8E1 60%, #E2E0D5 100%) !important;
  position: relative;
  min-height: 100vh;
}

body::before {
  content: '';
  position: fixed;
  top: -10%;
  left: -10%;
  width: 50%;
  height: 50%;
  background: radial-gradient(circle, rgba(89, 94, 70, 0.08) 0%, rgba(89, 94, 70, 0) 70%);
  z-index: 0;
  pointer-events: none;
}

body::after {
  content: '';
  position: fixed;
  bottom: -10%;
  right: -10%;
  width: 60%;
  height: 60%;
  background: radial-gradient(circle, rgba(163, 168, 142, 0.1) 0%, rgba(163, 168, 142, 0) 70%);
  z-index: 0;
  pointer-events: none;
}

/* --- Layout Column Styles & Modern Glassmorphism Layout --- */
#layout {
  background: transparent !important;
  position: relative;
  z-index: 1;
}

/* Glassmorphic Cards for Desktop view */
@media screen and (min-width: 769px) {
  #layout-menu {
    margin: 12px 6px 12px 12px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(253, 252, 249, 0.45) !important;
    backdrop-filter: blur(25px) !important;
    -webkit-backdrop-filter: blur(25px) !important;
    border: 1px solid rgba(255, 255, 255, 0.5) !important;
    box-shadow: var(--shadow-md) !important;
  }

  #layout-sidebar {
    margin: 12px 6px 12px 6px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(242, 241, 234, 0.55) !important;
    backdrop-filter: blur(25px) !important;
    -webkit-backdrop-filter: blur(25px) !important;
    border: 1px solid rgba(255, 255, 255, 0.45) !important;
    box-shadow: var(--shadow-md) !important;
    border-right: 0 !important;
  }

  #layout-list {
    margin: 12px 6px 12px 6px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(255, 255, 255, 0.6) !important;
    backdrop-filter: blur(25px) !important;
    -webkit-backdrop-filter: blur(25px) !important;
    border: 1px solid rgba(255, 255, 255, 0.5) !important;
    box-shadow: var(--shadow-md) !important;
    border-right: 0 !important;
  }

  #layout-content {
    margin: 12px 12px 12px 6px !important;
    border-radius: var(--radius-lg) !important;
    background: rgba(255, 255, 255, 0.75) !important;
    backdrop-filter: blur(25px) !important;
    -webkit-backdrop-filter: blur(25px) !important;
    border: 1px solid rgba(255, 255, 255, 0.6) !important;
    box-shadow: var(--shadow-md) !important;
  }
}

/* Translucency for column sub-sections */
#layout > div > .header,
#layout-sidebar > .header,
#layout-list > .header,
#layout-content > .header {
  background: transparent !important;
  border-bottom: 1px solid rgba(89, 94, 70, 0.08) !important;
}

#layout > div > .footer,
#layout-sidebar > .footer,
#layout-list > .footer,
#layout-content > .footer {
  background: transparent !important;
  border-top: 1px solid rgba(89, 94, 70, 0.08) !important;
}

.scroller,
#layout-sidebar .scroller,
#layout-list .scroller,
#layout-content .scroller,
#layout-content .content {
  background: transparent !important;
}

#layout-content iframe {
  background-color: #FFFFFF !important;
  border-radius: var(--radius-md) !important;
}

/* Search bar glass style */
.searchbar,
.searchbar input,
.header input.search-input {
  background-color: rgba(255, 255, 255, 0.4) !important;
  border: 1px solid rgba(89, 94, 70, 0.1) !important;
}

/* --- Far-Left Navigation Menu (#layout-menu) --- */
#layout-menu {
  border-right: 1px solid var(--border-color) !important;
}

#layout-menu .popover-header {
  background: transparent !important;
  border-bottom: 0 !important;
  padding: 16px 0 !important;
  height: auto !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

#layout-menu #logo {
  max-width: 42px !important;
  height: auto !important;
  border-radius: 10px !important;
}

#layout-menu .special-buttons {
  background: transparent !important;
  width: 100% !important;
  position: absolute !important;
  bottom: 12px !important;
}

/* Clean floating rounded capsules for sidebar link items */
#layout-menu a {
  border-radius: 12px !important;
  margin: 4px 8px !important;
  padding: 8px 4px !important;
  display: block !important;
  width: auto !important;
  text-align: center !important;
  background: transparent !important;
  border: 0 !important;
  box-sizing: border-box !important;
  color: var(--text-muted) !important;
  transition: var(--transition) !important;
  white-space: normal !important;
  text-overflow: clip !important;
  overflow: visible !important;
  word-break: break-word !important;
  font-size: 0.72rem !important;
}

#layout-menu a span,
#layout-menu a .inner {
  white-space: normal !important;
  text-overflow: clip !important;
  overflow: visible !important;
  display: block !important;
}

#layout-menu a:hover {
  background: rgba(89, 94, 70, 0.08) !important;
  color: var(--primary-color) !important;
}

#layout-menu a.selected,
#layout-menu a:active,
#layout-menu .action-buttons a.compose.selected {
  background: var(--primary-color) !important;
  color: #FFFFFF !important;
  box-shadow: var(--shadow-sm) !important;
}

/* Float compose button elegantly */
#layout-menu .action-buttons a.compose {
  background: rgba(89, 94, 70, 0.12) !important;
  color: var(--primary-color) !important;
  font-weight: 700 !important;
}

#layout-menu .action-buttons a.compose:hover {
  background: var(--primary-color) !important;
  color: #FFFFFF !important;
}

/* Hide theme/dark-mode and about/feedback toggle buttons */
#layout-menu a.theme,
#layout-menu a.about {
  display: none !important;
}

/* --- Custom Scrollbar --- */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

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

::-webkit-scrollbar-thumb {
  background: rgba(156, 163, 175, 0.4);
  border-radius: var(--radius-sm);
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(156, 163, 175, 0.6);
}


/* --- Brand Accents & Button Overrides --- */
a {
  color: var(--primary-color);
}

a:hover {
  color: var(--primary-hover);
}

.btn-primary, 
.button.mainaction,
.button.submit,
#rcmloginsubmit {
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  color: #FFFFFF !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 600 !important;
  transition: var(--transition) !important;
}

.btn-primary:hover, 
.button.mainaction:hover,
.button.submit:hover {
  background-color: var(--primary-hover) !important;
  border-color: var(--primary-hover) !important;
}

.listitem.selected,
.listitem.selected > a,
.listlinks li.selected,
.listlinks li.selected > a {
  background-color: rgba(89, 94, 70, 0.1) !important;
  color: var(--primary-color) !important;
  font-weight: 600 !important;
}

table.messagelist tr.selected td {
  background-color: rgba(89, 94, 70, 0.08) !important;
}

table.messagelist tr.selected.unread td {
  background-color: rgba(89, 94, 70, 0.12) !important;
}

table.messagelist tr.unread td {
  font-weight: 700 !important;
}

.form-control:focus {
  border-color: var(--primary-color) !important;
  box-shadow: 0 0 0 3px rgba(89, 94, 70, 0.15) !important;
}

/* ========================================================================= */
/* --- 2026 Split-Screen Login Page Layout (Matching Mockup Exactly) --- */
/* ========================================================================= */

body.task-login {
  background-color: var(--bg-page) !important;
  min-height: 100vh !important;
  margin: 0 !important;
  display: block !important;
}

body.task-login #layout {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 auto !important;
  width: 100% !important;
  max-width: 1060px !important;
  height: auto !important;
  display: block !important;
}

body.task-login #login-form {
  top: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  position: static !important;
}

/* Main Split Wrapper */
.login-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100vh;
  box-sizing: border-box;
  padding: 20px;
}

.login-card {
  display: flex;
  width: 100%;
  background: #FFFFFF;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  min-height: 620px;
}

/* Left Section: Branding & Slogan */
.login-left {
  width: 46%;
  background-color: #F2F1EA; /* Warm beige */
  padding: 48px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  box-sizing: border-box;
  border-right: 1px solid var(--border-color);
}

.brand-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 40px;
}

.brand-logo-container {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.brand-logo {
  max-width: 100%;
  height: auto;
}

.brand-name {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-main);
  letter-spacing: -0.3px;
}

.promo-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background-color: #FFFFFF;
  border-radius: 30px;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--primary-color);
  border: 1px solid rgba(89, 94, 70, 0.15);
  width: max-content;
  margin-bottom: 30px;
  letter-spacing: 0.8px;
  box-shadow: var(--shadow-sm);
}

.promo-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 2.85rem !important;
  line-height: 1.2 !important;
  font-weight: 600 !important;
  color: var(--text-main) !important;
  margin-bottom: 20px !important;
  letter-spacing: -0.5px;
}

.promo-desc {
  font-size: 0.95rem !important;
  line-height: 1.65 !important;
  color: #5C6050 !important;
  margin-bottom: 40px !important;
  max-width: 95%;
}

.promo-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--primary-color);
  letter-spacing: 0.8px;
  margin-top: auto;
}

.footer-bullet {
  color: #C4C6C0;
}

.slider-dots {
  display: flex;
  gap: 8px;
  margin-top: 30px;
}

.slider-dots .dot {
  width: 16px;
  height: 3px;
  background: rgba(89, 94, 70, 0.2);
  border-radius: 2px;
  transition: var(--transition);
}

.slider-dots .dot.active {
  width: 28px;
  background: var(--primary-color);
}

/* Right Section: Form Control */
.login-right {
  width: 54%;
  padding: 48px 64px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  box-sizing: border-box;
}

.form-header {
  margin-bottom: 30px;
}

.form-header h2 {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-main);
  margin-bottom: 8px;
  letter-spacing: -0.5px;
}

.form-header p {
  font-size: 0.95rem;
  color: var(--text-muted);
  margin: 0;
}

.form-group {
  margin-bottom: 24px;
}

.form-group label {
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  color: var(--text-muted) !important;
  letter-spacing: 0.8px !important;
  margin-bottom: 8px !important;
  display: block;
  text-transform: uppercase;
}

.label-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.label-row label {
  margin-bottom: 0 !important;
}

.forgot-link {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--primary-color);
  text-decoration: none;
}

.forgot-link:hover {
  text-decoration: underline;
}

/* Rounded inputs & icons */
.input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.input-icon {
  position: absolute;
  left: 16px;
  color: #A6A99E;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.input-wrapper .form-control {
  width: 100% !important;
  height: auto !important;
  border: 1px solid #E6E7E3 !important;
  background: #FBFBFA !important;
  padding: 15px 16px 15px 44px !important;
  border-radius: var(--radius-md) !important;
  font-size: 0.95rem !important;
  color: var(--text-main) !important;
  transition: var(--transition) !important;
  box-shadow: var(--shadow-sm) !important;
}

.input-wrapper .form-control:focus {
  border-color: var(--primary-color) !important;
  background: #FFFFFF !important;
  box-shadow: 0 0 0 4px rgba(89, 94, 70, 0.08) !important;
  outline: none !important;
}

.password-toggle {
  position: absolute;
  right: 16px;
  background: none;
  border: none;
  color: #A6A99E;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: var(--transition);
}

.password-toggle:hover {
  color: var(--primary-color);
}

/* Checkbox */
.form-check {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 28px;
  padding-left: 0 !important;
}

.form-check input[type="checkbox"] {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 1.5px solid #C4C6C0;
  cursor: pointer;
  accent-color: var(--primary-color);
  margin: 0;
}

.form-check label {
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: #5C6050 !important;
  margin: 0 !important;
  cursor: pointer;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Button */
.btn-submit {
  width: 100%;
  border: none;
  background: var(--primary-color);
  color: #FFFFFF;
  font-size: 0.9rem;
  font-weight: 700;
  padding: 16px;
  border-radius: var(--radius-md);
  cursor: pointer;
  letter-spacing: 0.8px;
  transition: var(--transition);
  box-shadow: var(--shadow-hover);
}

.btn-submit:hover {
  background: var(--primary-hover);
  transform: translateY(-1.5px);
  box-shadow: 0 16px 32px -5px rgba(89, 94, 70, 0.35);
}

.btn-submit:active {
  transform: translateY(0.5px);
}

/* Quick Access / Test Accounts */
.test-accounts {
  margin-top: 24px;
  border-top: 1px solid #F0F1EE;
  padding-top: 20px;
}

.test-title {
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  color: var(--text-muted) !important;
  margin-bottom: 12px !important;
  text-align: center;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.test-buttons {
  display: flex;
  gap: 10px;
  justify-content: center;
}

.btn-test {
  border: 1px solid #E6E7E3;
  background: #FFFFFF;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 600;
  color: #5C6050;
  cursor: pointer;
  transition: var(--transition);
}

.btn-test:hover {
  background: #F2F1EA;
  border-color: var(--primary-color);
  color: var(--primary-color);
}

.brand-footer-text {
  margin-top: 30px;
  font-size: 0.8rem;
  font-weight: 600;
  color: #B3B5AE;
  text-align: center;
}

/* Hide standard layout-content elements on login to avoid duplicate/default layout elements */
body.task-login #layout-content:not(.selected) {
  display: none !important;
}

/* --- Mobile Responsiveness --- */
@media (max-width: 860px) {
  body.task-login {
    height: auto !important;
    padding: 24px 16px !important;
  }
  
  .login-card {
    flex-direction: column;
    min-height: auto;
    border-radius: 20px;
  }
  
  .login-left {
    width: 100%;
    padding: 32px;
    border-right: none;
    border-bottom: 1px solid var(--border-color);
  }
  
  .login-right {
    width: 100%;
    padding: 32px 24px;
  }
  
  .promo-title {
    font-size: 2.2rem !important;
  }
  
  .brand-header {
    margin-bottom: 24px;
  }
}

/* --- Floating Toast Popup Notification Style --- */
body.task-login #messagestack {
  position: fixed !important;
  top: 24px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 99999 !important;
  width: auto !important;
  min-width: 320px !important;
  max-width: 480px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

body.task-login #messagestack > div {
  margin: 0 !important;
  background: #FFFFFF !important;
  border-radius: 12px !important;
  box-shadow: 0 10px 30px -5px rgba(0,0,0,0.1), 0 2px 8px -2px rgba(0,0,0,0.05) !important;
  border: 1px solid var(--border-color) !important;
  padding: 16px 20px !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  display: flex !important;
  align-items: center !important;
  animation: toast-fade-in 0.35s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

/* Success notification (Green/Olive tone) */
body.task-login #messagestack > div.success {
  border-left: 4px solid #10B981 !important;
  color: #065F46 !important;
  background: #ECFDF5 !important;
}

/* Error/Warning/Notice notifications */
body.task-login #messagestack > div.error {
  border-left: 4px solid #EF4444 !important;
  color: #991B1B !important;
  background: #FEF2F2 !important;
}

body.task-login #messagestack > div.warning {
  border-left: 4px solid #F59E0B !important;
  color: #92400E !important;
  background: #FFFBEB !important;
}

body.task-login #messagestack > div.notice {
  border-left: 4px solid #3B82F6 !important;
  color: #1E3A8A !important;
  background: #EFF6FF !important;
}

@keyframes toast-fade-in {
  from {
    opacity: 0;
    transform: translate(-50%, -20px);
  }
  to {
    opacity: 1;
    transform: translate(-50%, 0);
  }
}
