/*
* demo.css
* File include item demo only specific css only
******************************************************************************/

.menu .app-brand.demo {
  height: 90px;
  margin-top: 12px;
}

.app-brand-logo.demo svg {
  width: 22px;
  height: 38px;
}

.app-brand-text.demo {
  font-size: 1.75rem;
  letter-spacing: -0.5px;
}

.app-brand-text {
  font-size: 0.75rem;
  letter-spacing: -0.5px;
  width: 100%;
  display: inline-block;
  text-align: end;
}

/* ! For .layout-navbar-fixed added fix padding top to .layout-page */
/* Detached navbar */
.layout-navbar-fixed .layout-wrapper:not(.layout-horizontal):not(.layout-without-menu) .layout-page {
  padding-top: 74px !important;
}

/* Default navbar */
.layout-navbar-fixed .layout-wrapper:not(.layout-without-menu) .layout-page {
  padding-top: 64px !important;
}

.docs-page .layout-navbar-fixed.layout-wrapper:not(.layout-without-menu) .layout-page,
.docs-page .layout-menu-fixed.layout-wrapper:not(.layout-without-menu) .layout-page {
  padding-top: 62px !important;
}

/* Navbar page z-index issue solution */
.content-wrapper .navbar {
  z-index: auto;
}

/*
* Content
******************************************************************************/

.demo-blocks>* {
  display: block !important;
}

.demo-inline-spacing>* {
  margin: 1rem 0.375rem 0 0 !important;
}

/* ? .demo-vertical-spacing class is used to have vertical margins between elements. To remove margin-top from the first-child, use .demo-only-element class with .demo-vertical-spacing class. For example, we have used this class in forms-input-groups.html file. */
.demo-vertical-spacing>* {
  margin-top: 1rem !important;
  margin-bottom: 0 !important;
}

.demo-vertical-spacing.demo-only-element> :first-child {
  margin-top: 0 !important;
}

.demo-vertical-spacing-lg>* {
  margin-top: 1.875rem !important;
  margin-bottom: 0 !important;
}

.demo-vertical-spacing-lg.demo-only-element> :first-child {
  margin-top: 0 !important;
}

.demo-vertical-spacing-xl>* {
  margin-top: 5rem !important;
  margin-bottom: 0 !important;
}

.demo-vertical-spacing-xl.demo-only-element> :first-child {
  margin-top: 0 !important;
}

.rtl-only {
  display: none !important;
  text-align: left !important;
  direction: ltr !important;
}

[dir='rtl'] .rtl-only {
  display: block !important;
}

/* Dropdown buttons going out of small screens */
@media (max-width: 576px) {
  #dropdown-variation-demo .btn-group .text-truncate {
    width: 231px;
    position: relative;
  }

  #dropdown-variation-demo .btn-group .text-truncate::after {
    position: absolute;
    top: 45%;
    right: 0.65rem;
  }
}

/*
* Layout demo
******************************************************************************/

.layout-demo-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-top: 1rem;
}

.layout-demo-placeholder img {
  width: 900px;
}

.layout-demo-info {
  text-align: center;
  margin-top: 1rem;
}

.hover-primary:hover {
  background-color: #ebeef0;
}

.hover-success:hover {
  background-color: #e8fadf;
}

.active-primary {
  background-color: #ebeef0;
}

.active-success {
  background-color: #e8fadf;
}

.hover-dark {
  filter: brightness(0.85);
}

.hover-dark:hover {
  filter: brightness(0.85);
}

.hover-warning:hover {
  background-color: #fff2d6;
}

.hover-info:hover {
  background-color: #d7f5fc;
}

.hover-danger:hover {
  background-color: #ffe0db;
}

.hover-blue:hover {
  background-color: #cddaff;
}

.active-warning {
  background-color: #fff2d6;
}

.active-info {
  background-color: #d7f5fc;
}

.active-danger {
  background-color: #ffe0db;
}

.active-blue {
  background-color: #cddaff;
}

.active-secondary {
  background-color: #cbcbcb8c;
}

.mb-3>small {
  color: red;
}

.expanded {
  height: 200px;
  /* Adjust height as needed */
  overflow-y: auto;
}

.hover-cursor {
  cursor: pointer;
}

.orderNoteItem a i {
  color: grey;
}

.orderNoteItem:hover a i {
  color: black !important;
  cursor: pointer;
}

.orderNoteItem:hover {
  cursor: pointer;
}

.payment-methods {
  display: flex;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}

.payment-option {
  position: relative;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
  padding: 1.5rem;
  width: 130px;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.payment-option:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.payment-option img {
  width: 100%;
  max-width: 100px;
  height: auto;
  object-fit: contain;
}

.payment-option.soon::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  color: #fff;
  font-weight: 600;
  display: flex;
  align-items: end;
  justify-content: center;
  border-radius: 16px;
  font-size: 1.2rem;
  z-index: 1;
  cursor: not-allowed;
}

/* --- Audit Flow Layout --- */
.audit-flow {
  --bg: #fff;
  --fg: #0f172a;
  --muted: #64748b;
  --stroke: #cbd5e1;
  --created: #059669;
  --updated: #2563eb;
  --deleted: #dc2626;
  --shadow: 0 2px 10px rgba(2,6,23,0.07);

  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
  align-items: start;
  position: relative;
  padding: .5rem;
  max-width: 100%;
}

/* --- Step Boxes --- */
.audit-flow .step {
  background: var(--bg);
  color: var(--fg);
  border: 1px solid var(--stroke);
  border-radius: 14px;
  box-shadow: var(--shadow);
  padding: 1rem 1.1rem 1.1rem;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.audit-flow .step:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 12px rgba(2,6,23,0.12);
}

/* --- Header --- */
.step-header {
  display: grid;
  gap: .15rem;
  margin-bottom: .6rem;
}
.step-header .title {
  font-weight: 600;
}
.step-header .meta {
  font-size: .85rem;
  color: var(--muted);
}

/* --- Badge --- */
.badge {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  padding: .25rem .5rem;
  border-radius: 999px;
  background: #e2e8f0;
  color: #334155;
  width: max-content;
}
.step.created .badge { background: color-mix(in srgb, var(--created) 15%, white); color: var(--created); }
.step.updated .badge { background: color-mix(in srgb, var(--updated) 15%, white); color: var(--updated); }
.step.deleted .badge { background: color-mix(in srgb, var(--deleted) 15%, white); color: var(--deleted); }

/* --- Diff block --- */
.diff {
  list-style: none;
  margin: .2rem 0 0;
  padding: 0;
  display: grid;
  gap: .4rem;
}
.diff li {
  font-size: .92rem;
  line-height: 1.35rem;
  background: #f8fafc;
  border: 1px dashed var(--stroke);
  border-radius: 10px;
  padding: .5rem .6rem;
}
.diff code {
  background: #e2e8f0;
  padding: .05rem .35rem;
  border-radius: 6px;
  font-size: .85em;
}
.diff .old { text-decoration: line-through; opacity: .7; }
.diff .new { font-weight: 600; }
.diff .arrow { padding: 0 .35rem; opacity: .7; }

/* --- Responsive --- */
@media (max-width: 1200px) {
  .audit-flow {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  }
}

@media (max-width: 700px) {
  .audit-flow {
    grid-template-columns: 1fr;
  }
}

/* --- Dark mode --- */
@media (prefers-color-scheme: dark) {
  .audit-flow {
    --bg: #0b1220;
    --fg: #e5e7eb;
    --muted: #94a3b8;
    --stroke: #243146;
    --shadow: 0 2px 10px rgba(0,0,0,0.35);
  }
  .diff li { background: #0f172a; }
  .diff code { background: #1f2a3a; }
}

/* Ideas sidebars: ensure they render above Bootstrap's offcanvas backdrop (z-index 1089) */
.ideias-list-sidebar.offcanvas-end {
  z-index: 1095;
}
.ideias-detail-sidebar.offcanvas-start {
  right: var(--bs-offcanvas-width, 400px);
  width: var(--bs-offcanvas-width, 400px);
  z-index: 1100;
}
.ideias-list-sidebar {
  pointer-events: auto;
}

.ideias-list-sidebar:focus,
.ideias-list-sidebar *:focus {
  outline: none;
}