:root {
  --dbc-font-serif:      Georgia, Cambria, "Times New Roman", Times, serif;
  --tblr-font-sans-serif: var(--dbc-font-serif);
  --tblr-primary:        #00704A;
  --tblr-primary-rgb:    0, 112, 74;
  --tblr-primary-lt:     #E3F2EC;
  --dbc-cream:           #F5EFE6;
  --dbc-warm-dark:       #1E3932;
  --dbc-ink:             #0B2A24;
  --dbc-gold:            #CBA258;
  --dbc-sage:            #3F6E50;
  --dbc-clay:            #006241;
  --dbc-paper:           #fbfaf7;

  /* Semantic palette diselaraskan dengan tema Starbucks */
  --tblr-success:        #1F8A5C;
  --tblr-success-rgb:    31, 138, 92;
  --tblr-success-lt:     #E1F1E8;
  --tblr-warning:        #C18B26;
  --tblr-warning-rgb:    193, 139, 38;
  --tblr-warning-lt:     #FBEFD4;
  --tblr-danger:         #B0432E;
  --tblr-danger-rgb:     176, 67, 46;
  --tblr-danger-lt:      #F7E2DC;
  --tblr-secondary:      #5E7068;
  --tblr-secondary-rgb:  94, 112, 104;
  --tblr-secondary-lt:   #E5EAE7;
  --tblr-info:           #2F6F7F;
  --tblr-info-rgb:       47, 111, 127;
  --tblr-info-lt:        #DEEBEF;
}

@font-face {
  font-family: "tabler-icons";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../tabler/fonts/tabler-icons.woff2?v3.44.0") format("woff2"),
       url("../tabler/fonts/tabler-icons.woff?v3.44.0") format("woff"),
       url("../tabler/fonts/tabler-icons.ttf?v3.44.0") format("truetype");
}

/* Override warna tombol Bootstrap/Tabler agar kontras serasi dengan hijau Starbucks */
.btn-success      { --tblr-btn-bg: var(--tblr-success); --tblr-btn-border-color: var(--tblr-success); --tblr-btn-hover-bg: #176A47; --tblr-btn-hover-border-color: #176A47; --tblr-btn-active-bg: #135838; --tblr-btn-active-border-color: #135838; color: #fff; }
.btn-warning      { --tblr-btn-bg: var(--tblr-warning); --tblr-btn-border-color: var(--tblr-warning); --tblr-btn-hover-bg: #A1731D; --tblr-btn-hover-border-color: #A1731D; color: #fff; }
.btn-danger       { --tblr-btn-bg: var(--tblr-danger); --tblr-btn-border-color: var(--tblr-danger); --tblr-btn-hover-bg: #913523; --tblr-btn-hover-border-color: #913523; color: #fff; }
.btn-secondary    { --tblr-btn-bg: var(--tblr-secondary); --tblr-btn-border-color: var(--tblr-secondary); --tblr-btn-hover-bg: #4C5C55; --tblr-btn-hover-border-color: #4C5C55; color: #fff; }

.bg-success, .badge.bg-success { background-color: var(--tblr-success) !important; color: #fff; }
.bg-warning, .badge.bg-warning { background-color: var(--tblr-warning) !important; color: #fff; }
.bg-danger,  .badge.bg-danger  { background-color: var(--tblr-danger)  !important; color: #fff; }
.bg-secondary,.badge.bg-secondary { background-color: var(--tblr-secondary) !important; color: #fff; }
.bg-info,    .badge.bg-info    { background-color: var(--tblr-info)    !important; color: #fff; }

.text-success { color: var(--tblr-success) !important; }
.text-warning { color: var(--tblr-warning) !important; }
.text-danger  { color: var(--tblr-danger)  !important; }
.text-info    { color: var(--tblr-info)    !important; }

body,
button,
input,
select,
textarea,
.dropdown-menu,
.popover,
.tooltip {
  font-family: var(--dbc-font-serif);
}

.table,
.form-control,
.form-select,
.btn,
.badge {
  font-family: var(--dbc-font-serif);
}

.ti {
  font-family: "tabler-icons" !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
.page-title,
.navbar-brand,
.card-title,
.dbc-kicker {
  font-family: var(--dbc-font-serif);
  font-weight: 850;
}
.navbar-vertical {
  background-color: var(--dbc-warm-dark) !important;
}
.navbar-vertical .nav-link { color: rgba(255,255,255,0.75); }
.navbar-vertical .nav-link:hover,
.navbar-vertical .nav-link.active {
  color: #fff;
  background-color: rgba(255,255,255,0.1);
}

.dbc-admin-body {
  background: #f4f6f8;
  color: #1b1f23;
}

.dbc-admin-sidebar {
  box-shadow: 10px 0 30px rgba(23, 20, 18, .12);
}

.dbc-admin-brand {
  padding-top: 1rem;
  padding-bottom: .75rem;
}

.dbc-admin-brand a {
  display: grid;
  grid-template-columns: 40px 1fr;
  column-gap: 10px;
  align-items: center;
}

.dbc-admin-brand span {
  grid-row: span 2;
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--dbc-gold);
  color: var(--dbc-ink);
}

.dbc-admin-brand strong {
  line-height: 1;
  font-size: 1.1rem;
}

.dbc-admin-brand img,
.dbc-public-nav .dbc-brand-mark img,
.dbc-login-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.dbc-admin-brand small {
  color: rgba(255,255,255,.58);
  font-size: .72rem;
  letter-spacing: 0;
}

.dbc-sidebar-label {
  padding: 18px 12px 7px;
  color: rgba(255,255,255,.44);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.dbc-sidebar-nav .nav-link {
  border-radius: 8px;
  margin: 1px 8px;
}

.dbc-sidebar-nav .nav-link-icon {
  color: var(--dbc-gold);
}

.dbc-stock-alert {
  border-top: 1px solid rgba(255,255,255,.08);
  margin: 12px 8px 0;
}

.dbc-admin-topbar {
  min-height: 66px;
  background: #fff;
  border-bottom: 1px solid rgba(29, 35, 39, .08);
}

.dbc-admin-context {
  display: grid;
  line-height: 1.2;
}

.dbc-admin-context span {
  color: #66717c;
  font-size: .78rem;
}

.dbc-admin-context strong {
  font-size: .92rem;
}

.dbc-admin-page-header {
  padding-top: 20px;
  padding-bottom: 0;
}

.dbc-admin-breadcrumb {
  color: #7b858f;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
  margin-bottom: 5px;
}

.dbc-admin-alert-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 10px;
  padding: 7px 10px;
  border-radius: 8px;
  background: #fff4e6;
  color: #8a4b00;
  font-weight: 700;
  font-size: .85rem;
}

.dbc-admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
}

.dbc-admin-toolbar h3 {
  margin: 2px 0 0;
  font-weight: 850;
}

.dbc-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.dbc-stat-grid.compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dbc-stat-card {
  min-height: 118px;
  display: grid;
  align-content: space-between;
  gap: 8px;
  padding: 16px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
}

.dbc-stat-card span {
  color: #66717c;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.dbc-stat-card strong {
  font-size: 1.75rem;
  line-height: 1.05;
}

.dbc-stat-card small {
  color: #7b858f;
}

.dbc-stat-card.danger {
  border-color: rgba(214, 57, 57, .22);
  background: #fff7f7;
}

.dbc-table-card,
.dbc-form-card {
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  box-shadow: 0 14px 34px rgba(29,35,39,.05);
}

.dbc-form-card .card-subtitle {
  margin: 0;
  color: #7b858f;
}

.dbc-table-card .card-header {
  min-height: 70px;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.dbc-table-card .card-subtitle {
  margin: 4px 0 0;
  color: #7b858f;
}

.dbc-table-card thead th {
  color: #66717c;
  font-size: .75rem;
  letter-spacing: 0;
  text-transform: uppercase;
}

.dbc-row-icon {
  flex: 0 0 38px;
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--tblr-primary-lt);
  color: var(--tblr-primary);
  font-size: 1.2rem;
}

.dbc-empty.compact {
  padding: 16px;
  text-align: center;
  box-shadow: none;
}

.dbc-stock-alert-panel {
  display: grid;
  grid-template-columns: minmax(220px, .45fr) minmax(0, 1fr);
  gap: 18px;
  padding: 18px;
  border: 1px solid rgba(214, 57, 57, .2);
  border-radius: 8px;
  background: #fff7f7;
}

.dbc-stock-alert-panel h3 {
  margin: 2px 0 0;
  font-weight: 850;
}

.dbc-stock-alert-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.dbc-stock-alert-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 56px;
  padding: 10px 12px;
  border: 1px solid rgba(214, 57, 57, .18);
  border-radius: 8px;
  background: #fff;
  color: #1b1f23;
  text-decoration: none;
}

.dbc-stock-alert-list span {
  color: #d63939;
  font-weight: 800;
  white-space: nowrap;
}

.dbc-stock-list .list-group-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.dbc-stock-list small {
  display: block;
  color: #7b858f;
}

.dbc-settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .42fr);
  gap: 18px;
  align-items: start;
}

.dbc-settings-main,
.dbc-settings-side {
  display: grid;
  gap: 16px;
}

.dbc-settings-side {
  position: sticky;
  top: 18px;
}

.dbc-settings-actions {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 16px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
}

.dbc-settings-preview {
  display: grid;
  gap: 18px;
  padding: 22px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(29,35,39,.05);
}

.dbc-settings-preview-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.dbc-settings-logo {
  width: 84px;
  height: 84px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--tblr-primary-lt);
  color: var(--tblr-primary);
  font-size: 2.6rem;
}

.dbc-settings-favicon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fbfaf7;
  color: var(--tblr-primary);
  font-size: 1.3rem;
}

.dbc-settings-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.dbc-settings-favicon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 5px;
}

.dbc-settings-preview h2 {
  margin: 4px 0 6px;
  font-weight: 900;
}

.dbc-settings-preview p {
  color: #66717c;
  margin: 0;
}

.dbc-seo-preview {
  padding: 14px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fbfaf7;
}

.dbc-seo-preview small,
.dbc-seo-preview strong,
.dbc-seo-preview p {
  display: block;
}

.dbc-seo-preview small {
  color: #55715f;
}

.dbc-seo-preview strong {
  margin: 4px 0;
  color: #1a0dab;
  font-size: 1.05rem;
}

.dbc-indexing-guide {
  display: grid;
  gap: 14px;
  margin-top: 6px;
  padding: 16px;
  border: 1px solid rgba(0,112,74,.16);
  border-radius: 8px;
  background: #f6fbf8;
}

.dbc-indexing-guide-head,
.dbc-indexing-flow,
.dbc-indexing-links {
  display: grid;
  gap: 10px;
}

.dbc-indexing-guide-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.dbc-indexing-guide h4 {
  margin: 2px 0 0;
  font-weight: 900;
}

.dbc-indexing-flow {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dbc-indexing-flow div,
.dbc-indexing-links label {
  padding: 12px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
}

.dbc-indexing-flow strong,
.dbc-indexing-flow span,
.dbc-indexing-links span,
.dbc-indexing-links code {
  display: block;
}

.dbc-indexing-flow span,
.dbc-indexing-links span {
  color: #66717c;
  font-size: .86rem;
}

.dbc-indexing-links {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dbc-indexing-links code {
  margin-top: 4px;
  color: var(--dbc-ink);
  white-space: normal;
  overflow-wrap: anywhere;
}

.dbc-indexing-checklist {
  display: grid;
  gap: 8px;
  color: #46525d;
  font-size: .9rem;
}

.dbc-indexing-checklist span {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.dbc-indexing-checklist i {
  color: var(--tblr-primary);
  margin-top: 2px;
}

.dbc-settings-contact {
  display: grid;
  gap: 8px;
  color: #66717c;
}

.dbc-settings-contact span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.dbc-settings-contact i {
  color: var(--tblr-primary);
}

.dbc-social-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.dbc-social-input {
  display: grid;
  gap: 7px;
}

.dbc-social-input span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #46525d;
  font-size: .86rem;
  font-weight: 750;
}

.dbc-social-input i {
  color: var(--tblr-primary);
}

.dbc-settings-note,
.dbc-settings-file {
  color: #66717c;
  font-size: .86rem;
}

.dbc-settings-file {
  display: flex;
  gap: 12px;
  padding: 14px;
  border: 1px dashed rgba(29,35,39,.18);
  border-radius: 8px;
  background: #fff;
}

.dbc-settings-file i {
  color: var(--tblr-primary);
  font-size: 1.4rem;
}

.dbc-settings-file strong,
.dbc-settings-file span {
  display: block;
}

.dbc-settings-file span {
  overflow-wrap: anywhere;
}

.dbc-article-editor-card .card-header {
  align-items: center;
  justify-content: space-between;
}

.dbc-html-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(29,35,39,.12);
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  background: #f6f7f8;
}

.dbc-html-editor {
  min-height: 360px;
  padding: 18px;
  border: 1px solid rgba(29,35,39,.12);
  border-radius: 0 0 8px 8px;
  background: #fff;
  line-height: 1.75;
  outline: none;
}

.dbc-html-editor:focus {
  border-color: var(--tblr-primary);
  box-shadow: 0 0 0 3px rgba(32,107,196,.12);
}

.dbc-html-editor-compact {
  min-height: 190px;
}

.dbc-kasir-head,
.dbc-kasir-detail-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(29,35,39,.04);
}

.dbc-kasir-head h3,
.dbc-kasir-detail-head h3 {
  margin: 2px 0 4px;
  font-weight: 900;
}

.dbc-kasir-head p,
.dbc-kasir-detail-head p {
  margin: 0;
  color: #66717c;
}

.dbc-kasir-detail-head.compact {
  padding: 10px 12px;
  gap: 10px;
}

.dbc-kasir-detail-head.compact h3 {
  font-size: 1.2rem;
  margin: 0;
}

.dbc-kasir-detail-head.compact p {
  font-size: .86rem;
}

.dbc-kasir-detail-head.compact .btn {
  min-height: 34px;
  padding: 5px 10px;
}

.dbc-table-card .card-header.compact {
  min-height: 50px;
  padding: 8px 12px;
}

.dbc-table-card .card-header.compact .card-title {
  font-size: 1rem;
}

.dbc-kasir-widget-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.dbc-kasir-widget {
  min-height: 132px;
  display: grid;
  align-content: space-between;
  gap: 10px;
  padding: 16px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(29,35,39,.05);
}

.dbc-kasir-widget span {
  color: #66717c;
  font-size: .78rem;
  font-weight: 850;
  text-transform: uppercase;
}

.dbc-kasir-widget strong {
  font-size: 1.9rem;
  line-height: 1.05;
}

.dbc-kasir-widget small {
  color: #7b858f;
}

.dbc-kasir-widget.warning {
  background: #fff8e6;
  border-color: rgba(245, 159, 0, .24);
}

.dbc-kasir-widget.success {
  background: #f0fbf4;
  border-color: rgba(47, 179, 68, .22);
}

.dbc-kasir-widget.primary {
  background: #eef6ff;
  border-color: rgba(32, 107, 196, .2);
}

.dbc-next-payment {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border: 1px solid rgba(245, 159, 0, .24);
  border-radius: 8px;
  background: #fff8e6;
}

.dbc-next-payment h4,
.dbc-kasir-order-card h4 {
  margin: 0;
  font-weight: 900;
}

.dbc-next-payment p,
.dbc-kasir-order-card p {
  margin: 0;
  color: #66717c;
}

.dbc-kasir-order-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.dbc-kasir-order-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(29,35,39,.05);
}

.dbc-kasir-order-top {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.dbc-kasir-order-body {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.dbc-kasir-order-body div {
  padding: 10px;
  border-radius: 8px;
  background: #f6f7f8;
}

.dbc-kasir-order-body span {
  display: block;
  color: #7b858f;
  font-size: .74rem;
  font-weight: 800;
  text-transform: uppercase;
}

.dbc-kasir-order-body strong {
  display: block;
  margin-top: 3px;
}

.dbc-kasir-order-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.dbc-kasir-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .34fr);
  gap: 12px;
  align-items: start;
}

.dbc-kasir-detail-main {
  min-width: 0;
}

.dbc-queue-number.small {
  min-width: 48px;
  min-height: 48px;
}

.dbc-queue-number.small strong {
  font-size: 1.25rem;
}

.dbc-kasir-payment-panel {
  position: sticky;
  top: 12px;
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(29,35,39,.05);
}

.dbc-payment-total {
  padding: 12px;
  border-radius: 8px;
  background: var(--dbc-ink);
  color: #fff;
}

.dbc-payment-total span,
.dbc-payment-total small {
  display: block;
  color: rgba(255,255,255,.72);
}

.dbc-payment-total strong {
  display: block;
  margin: 3px 0;
  font-size: 1.55rem;
  line-height: 1.05;
}

.dbc-payment-methods {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.dbc-payment-methods label {
  cursor: pointer;
  margin: 0;
}

.dbc-payment-methods input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.dbc-payment-methods span {
  min-height: 66px;
  display: grid;
  place-items: center;
  text-align: center;
  gap: 2px;
  align-items: center;
  padding: 8px 6px;
  border: 1px solid rgba(29,35,39,.12);
  border-radius: 8px;
  background: #fff;
}

.dbc-payment-methods i {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--tblr-primary-lt);
  color: var(--tblr-primary);
}

.dbc-payment-methods strong {
  display: block;
  font-size: .84rem;
  line-height: 1.1;
}

.dbc-payment-methods small {
  display: none;
  color: #7b858f;
}

.dbc-payment-methods input:checked + span {
  border-color: var(--tblr-primary);
  box-shadow: 0 0 0 3px rgba(32,107,196,.12);
}

.dbc-cash-calculator {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(47,179,68,.18);
  border-radius: 8px;
  background: #f0fbf4;
}

.dbc-cash-calculator[hidden] {
  display: none;
}

.dbc-cash-shortcuts {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.dbc-cash-shortcuts .btn {
  padding: 5px 8px;
}

.dbc-cash-result {
  display: grid;
  gap: 2px;
  padding: 8px 10px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(47,179,68,.16);
}

.dbc-cash-result span {
  color: #66717c;
  font-size: .76rem;
  font-weight: 850;
  text-transform: uppercase;
}

.dbc-cash-result strong {
  color: #2fb344;
  font-size: 1.25rem;
  line-height: 1.1;
}

.dbc-cash-result small {
  color: #66717c;
}

.dbc-cash-result.danger {
  border-color: rgba(214,57,57,.22);
  background: #fff7f7;
}

.dbc-cash-result.danger strong {
  color: #d63939;
}

.dbc-transfer-panel {
  padding: 10px;
  border: 1px solid rgba(32,107,196,.18);
  border-radius: 8px;
  background: #eef6ff;
}

.dbc-transfer-panel[hidden] {
  display: none;
}

.dbc-status-timeline {
  display: grid;
  gap: 8px;
}

.dbc-status-timeline div {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 10px;
}

.dbc-status-timeline i {
  color: var(--tblr-primary);
  font-size: 1.15rem;
  margin-top: 2px;
}

.dbc-status-timeline small {
  display: block;
  color: #7b858f;
  margin-top: 2px;
}

.dbc-status-compact {
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
}

.dbc-status-compact summary {
  cursor: pointer;
  padding: 8px 12px;
  color: #66717c;
  font-weight: 800;
}

.dbc-status-compact > div {
  max-height: 160px;
  overflow-y: auto;
  padding: 0 12px 10px;
}

.dbc-kasir-detail-main .table > :not(caption) > * > * {
  padding: .45rem .6rem;
}

.dbc-kasir-detail-main .table strong {
  font-size: .95rem;
}

body:has(.dbc-kasir-detail-grid) .dbc-admin-page-header {
  padding-top: 10px;
  padding-bottom: 8px;
}

body:has(.dbc-kasir-detail-grid) .page-body {
  margin-top: 12px;
}

.dbc-production-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
}

.dbc-production-head h3 {
  margin: 2px 0 4px;
  font-weight: 900;
}

.dbc-production-head p {
  margin: 0;
  color: #66717c;
}

.dbc-production-clock {
  display: grid;
  min-width: 132px;
  padding: 12px;
  border-radius: 8px;
  background: var(--tblr-primary-lt);
  color: var(--tblr-primary);
}

.dbc-production-clock span,
.dbc-production-stat span {
  color: #66717c;
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.dbc-production-clock strong {
  font-size: 1.2rem;
}

.dbc-production-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.dbc-production-stat {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 86px;
  padding: 16px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fff;
}

.dbc-production-stat i {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--tblr-primary-lt);
  color: var(--tblr-primary);
  font-size: 1.35rem;
}

.dbc-production-stat strong {
  display: block;
  font-size: 1.8rem;
  line-height: 1;
}

.dbc-production-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}

.dbc-production-column {
  min-height: 440px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #f9fafb;
  overflow: hidden;
}

.dbc-production-column header {
  min-height: 84px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px;
  border-bottom: 1px solid rgba(29,35,39,.08);
  background: #fff;
}

.dbc-production-column h4,
.dbc-production-column p {
  margin: 0;
}

.dbc-production-column h4 {
  font-weight: 900;
}

.dbc-production-column p {
  color: #66717c;
  font-size: .9rem;
}

.dbc-production-column header > span {
  min-width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--tblr-primary);
  color: #fff;
  font-weight: 900;
}

.dbc-production-stack {
  display: grid;
  gap: 12px;
  padding: 12px;
}

.dbc-production-card {
  border: 1px solid rgba(29,35,39,.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(29,35,39,.06);
  overflow: hidden;
}

.dbc-production-card-top {
  display: grid;
  grid-template-columns: 70px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-bottom: 1px solid rgba(29,35,39,.08);
}

.dbc-queue-number {
  min-height: 66px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--dbc-ink);
  color: #fff;
}

.dbc-queue-number small {
  align-self: end;
  font-size: .68rem;
}

.dbc-queue-number strong {
  align-self: start;
  font-size: 2rem;
  line-height: 1;
}

.dbc-production-card h5 {
  margin: 0 0 4px;
  font-weight: 900;
}

.dbc-production-items {
  display: grid;
  gap: 7px;
  padding: 14px;
}

.dbc-production-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
}

.dbc-production-item strong {
  text-align: center;
  border-radius: 8px;
  background: #eef2ee;
}

.dbc-production-note,
.dbc-production-order-note {
  color: #8a4b00;
  font-size: .9rem;
}

.dbc-production-note {
  margin: -4px 0 4px 50px;
}

.dbc-label-locked {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 30px;
  padding: 5px 9px;
  border: 1px dashed rgba(94,112,104,.28);
  border-radius: 8px;
  background: #f6f7f8;
  color: #66717c;
  font-size: .82rem;
  font-weight: 800;
}

.dbc-production-order-note {
  display: flex;
  gap: 8px;
  margin: 0 14px 14px;
  padding: 10px;
  border-radius: 8px;
  background: #fff4e6;
}

.dbc-production-actions {
  padding: 0 14px 14px;
}

.dbc-production-empty {
  min-height: 170px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  border: 1px dashed rgba(29,35,39,.18);
  border-radius: 8px;
  color: #7b858f;
  background: #fff;
}

.dbc-production-empty i {
  font-size: 2rem;
  color: var(--tblr-primary);
}

.dbc-call-overlay {
  position: fixed;
  inset: 0;
  z-index: 1050;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(11,42,36,.82);
}

.dbc-call-panel {
  width: min(100%, 520px);
  padding: 28px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  background: var(--dbc-warm-dark);
  color: #fff;
  text-align: center;
  box-shadow: 0 24px 80px rgba(0,0,0,.28);
}

.dbc-call-number {
  margin: 14px auto;
  width: min(240px, 70vw);
  min-height: 150px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--dbc-gold);
  color: var(--dbc-ink);
  font-size: 5rem;
  font-weight: 900;
  line-height: 1;
}

.dbc-call-panel h3 {
  margin: 0 0 6px;
  font-size: 2rem;
  font-weight: 900;
}

.dbc-call-panel p {
  color: rgba(255,255,255,.7);
  margin-bottom: 18px;
}

.dbc-public {
  background: var(--dbc-paper);
  color: var(--dbc-ink);
}

.dbc-public-nav {
  background: rgba(11, 42, 36, .96);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.dbc-public-nav .navbar-brand {
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-weight: 800;
}

.dbc-public-nav .nav-link {
  color: rgba(255,255,255,.78);
  font-weight: 600;
}

.dbc-public-nav .nav-link:hover,
.dbc-public-nav .nav-link.active {
  color: #fff;
}

.dbc-brand-mark {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--dbc-gold);
  color: var(--dbc-ink);
}

.dbc-hero {
  background:
    linear-gradient(120deg, rgba(11,42,36,.97), rgba(30,57,50,.92));
  color: #f8f4ee;
  padding: 88px 0 68px;
}

.dbc-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, .75fr);
  gap: 40px;
  align-items: center;
}

.dbc-hero-copy h1,
.dbc-page-hero h1 {
  font-size: clamp(2.6rem, 6vw, 5.25rem);
  line-height: .95;
  font-weight: 900;
  margin: .25rem 0 1rem;
}

.dbc-hero-copy p,
.dbc-page-hero p {
  max-width: 680px;
  color: rgba(255,255,255,.76);
  font-size: 1.15rem;
}

.dbc-kicker {
  color: var(--dbc-gold);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.dbc-hero-board {
  min-height: 360px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  padding: 20px;
  display: grid;
  align-content: space-between;
  background: rgba(255,255,255,.06);
  box-shadow: 0 24px 80px rgba(0,0,0,.22);
}

.dbc-cup-visual {
  min-height: 160px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #f4efe8;
  color: var(--dbc-warm-dark);
  font-weight: 800;
}

.dbc-cup-visual i {
  font-size: 4.5rem;
  color: var(--dbc-clay);
}

.dbc-hero-stat {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: rgba(255,255,255,.72);
}

.dbc-hero-stat strong {
  color: #fff;
}

.dbc-about-section {
  padding: 52px 0;
  background: #f7f2ea;
  border-bottom: 1px solid rgba(23,20,18,.08);
}

.dbc-about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, .7fr);
  gap: 28px;
  align-items: center;
}

.dbc-about-copy h2 {
  font-size: clamp(1.9rem, 3.8vw, 3rem);
  font-weight: 850;
  margin: .25rem 0 .8rem;
}

.dbc-about-copy p {
  max-width: 760px;
  color: #5d554f;
  font-size: 1.08rem;
  line-height: 1.75;
  margin: 0;
}

.dbc-about-meta {
  display: grid;
  gap: 14px;
  padding: 22px;
  border: 1px solid rgba(23,20,18,.1);
  border-radius: 8px;
  background: #fff;
}

.dbc-about-line,
.dbc-footer-meta span {
  display: inline-flex;
  align-items: center;
  gap: 9px;
}

.dbc-about-line {
  color: var(--dbc-ink);
  font-weight: 750;
}

.dbc-about-line i,
.dbc-footer-meta i {
  color: var(--dbc-gold);
}

.dbc-social-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dbc-social-link {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 8px;
  border: 1px solid rgba(23,20,18,.12);
  background: #fff;
  color: var(--dbc-ink);
  text-decoration: none;
  font-weight: 750;
  padding: 8px 11px;
}

.dbc-social-link:hover {
  border-color: var(--dbc-gold);
  color: var(--dbc-warm-dark);
}

.dbc-location-section {
  padding: 58px 0;
  background: #fff;
}

.dbc-location-grid {
  display: grid;
  grid-template-columns: minmax(280px, .55fr) minmax(0, 1fr);
  gap: 24px;
  align-items: stretch;
}

.dbc-location-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: 8px;
  border: 1px solid rgba(23,20,18,.1);
  background: #f7f2ea;
  padding: 26px;
}

.dbc-location-copy h2 {
  font-size: clamp(1.7rem, 3vw, 2.45rem);
  font-weight: 850;
  margin: .25rem 0 .75rem;
}

.dbc-location-copy p {
  color: #5d554f;
  line-height: 1.7;
  margin-bottom: 20px;
}

.dbc-location-map {
  overflow: hidden;
  border-radius: 8px;
  border: 1px solid rgba(23,20,18,.1);
  background: #e9e1d8;
}

.dbc-location-map {
  min-height: 340px;
}

.dbc-location-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.dbc-section {
  padding: 64px 0;
}

.dbc-section-muted {
  background: #eef2ee;
}

.dbc-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
}

.dbc-section-head.compact {
  margin-bottom: 16px;
}

.dbc-section-head h2,
.dbc-menu-group h2 {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 850;
  margin: 0;
}

.dbc-card-grid,
.dbc-article-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.dbc-article-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dbc-public-card,
.dbc-article-card,
.dbc-list-card,
.dbc-side-panel {
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 8px;
  box-shadow: 0 10px 30px rgba(23,20,18,.06);
}

.dbc-public-card,
.dbc-article-card {
  overflow: hidden;
  height: 100%;
  text-decoration: none;
  color: inherit;
}

.dbc-card-media {
  position: relative;
  aspect-ratio: 16 / 10;
  background: #e9e1d8;
}

.dbc-card-media img,
.dbc-video-card img,
.dbc-article-cover,
.dbc-side-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dbc-card-placeholder {
  height: 100%;
  display: grid;
  place-items: center;
  color: var(--dbc-clay);
  font-size: 3rem;
  background: linear-gradient(135deg, #f7f2ea, #e5ece6);
}

.dbc-best-seller-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 9px;
  border-radius: 999px;
  background: var(--dbc-gold);
  color: var(--dbc-ink);
  font-size: .78rem;
  font-weight: 900;
  box-shadow: 0 8px 20px rgba(23,20,18,.16);
}

.dbc-menu-flags {
  min-height: 100%;
  display: grid;
  align-content: center;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fbfaf7;
}

.dbc-topping-editor {
  padding: 14px;
  border: 1px solid rgba(29,35,39,.08);
  border-radius: 8px;
  background: #fbfaf7;
}

.dbc-topping-rows {
  display: grid;
  gap: 8px;
}

.dbc-topping-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(110px, .35fr) 130px 42px;
  gap: 8px;
  align-items: center;
}

@media (max-width: 720px) {
  .dbc-indexing-guide-head,
  .dbc-indexing-flow,
  .dbc-indexing-links {
    grid-template-columns: 1fr;
  }

  .dbc-topping-row {
    grid-template-columns: 1fr;
  }

  .dbc-topping-row .btn-icon {
    width: 100%;
  }
}

.dbc-public-card-body {
  padding: 18px;
}

.dbc-public-card-body h3,
.dbc-public-card-body h2,
.dbc-list-card h3 {
  font-weight: 800;
  margin: .6rem 0 .4rem;
}

.dbc-public-card-body p,
.dbc-list-card p {
  color: #6c625c;
}

.dbc-price {
  color: var(--dbc-clay);
  font-weight: 900;
  font-size: 1.15rem;
}

.dbc-card-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
}

.dbc-list-card {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  margin-bottom: 12px;
  text-decoration: none;
  color: inherit;
}

.dbc-list-card i,
.dbc-read-more,
.dbc-side-link i {
  color: var(--dbc-sage);
}

.dbc-video-card {
  position: relative;
  width: 100%;
  border: 0;
  border-radius: 8px;
  overflow: hidden;
  padding: 0;
  margin-bottom: 14px;
  background: #000;
  color: #fff;
  text-align: left;
  aspect-ratio: 16 / 9;
}

.dbc-video-card.small {
  aspect-ratio: 16 / 9;
}

.dbc-video-card span {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 2.4rem;
  background: rgba(0,0,0,.22);
}

.dbc-video-card strong {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 12px;
}

/* ===== Landing refresh ===== */
.dbc-hero {
  padding: 96px 0 80px;
}

.dbc-hero-stats {
  display: grid;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.14);
}

.dbc-hero-board {
  gap: 18px;
}

.dbc-info-strip {
  background: var(--dbc-warm-dark, #1b1410);
  color: #f7f2ea;
  padding: 0;
  margin-top: -1px;
}

.dbc-info-strip-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border-left: 1px solid rgba(255,255,255,.08);
}

.dbc-info-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px 22px;
  border-right: 1px solid rgba(255,255,255,.08);
  color: inherit;
  text-decoration: none;
  transition: background .2s ease;
}

.dbc-info-item i {
  font-size: 1.6rem;
  color: var(--dbc-gold);
  flex-shrink: 0;
}

.dbc-info-item span {
  display: block;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: rgba(255,255,255,.55);
  font-weight: 700;
}

.dbc-info-item strong {
  display: block;
  font-size: .95rem;
  color: #fff;
  line-height: 1.3;
}

.dbc-info-item-link:hover {
  background: rgba(255,255,255,.05);
  color: #fff;
}

@media (max-width: 900px) {
  .dbc-info-strip-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 520px) {
  .dbc-info-strip-grid {
    grid-template-columns: 1fr;
  }
}

.dbc-heading-accent {
  position: relative;
  padding-bottom: 14px;
  margin-bottom: 16px;
}

.dbc-heading-accent::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 56px;
  height: 3px;
  border-radius: 2px;
  background: var(--dbc-gold);
}

.dbc-about-meta-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 12px;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(23,20,18,.08);
  font-size: 1.05rem;
}

.dbc-about-meta-head i {
  color: var(--dbc-gold);
  font-size: 1.4rem;
}

.dbc-public-card-hover {
  transition: transform .25s ease, box-shadow .25s ease;
}

.dbc-public-card-hover:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 42px rgba(23,20,18,.12);
}

.dbc-public-card-hover .dbc-card-media img {
  transition: transform .4s ease;
}

.dbc-public-card-hover:hover .dbc-card-media img {
  transform: scale(1.05);
}

.dbc-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
}

.dbc-price-chip {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 999px;
  background: #f7f2ea;
  color: var(--dbc-clay);
  font-weight: 900;
  font-size: 1rem;
}

.dbc-card-arrow {
  font-size: 1.1rem;
  color: var(--dbc-sage);
  transition: transform .25s ease;
}

.dbc-public-card-hover:hover .dbc-card-arrow {
  transform: translate(3px, -3px);
  color: var(--dbc-clay);
}

.dbc-location-fw {
  position: relative;
  padding: 80px 0;
  background: #fff;
}

.dbc-location-fw-map {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.dbc-location-fw-map::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(247,242,234,.96) 0%, rgba(247,242,234,.85) 38%, rgba(247,242,234,0) 65%);
}

.dbc-location-fw-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.dbc-location-fw .container-xl {
  position: relative;
  z-index: 2;
}

.dbc-location-overlay {
  max-width: 460px;
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 12px;
  padding: 30px;
  box-shadow: 0 24px 60px rgba(23,20,18,.14);
}

.dbc-location-overlay h2 {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 850;
  margin: .25rem 0 .75rem;
}

.dbc-location-overlay p {
  color: #5d554f;
  margin-bottom: .35rem;
}

@media (max-width: 900px) {
  .dbc-location-fw {
    padding: 0;
  }
  .dbc-location-fw-map {
    position: relative;
    height: 280px;
  }
  .dbc-location-fw-map::after {
    display: none;
  }
  .dbc-location-overlay {
    max-width: none;
    border-radius: 0;
    border: 0;
    box-shadow: none;
    padding: 36px 16px;
  }
}

/* Kecilkan heading di section 2-kolom (Artikel + Video) */
.dbc-section-head.compact h2 {
  font-size: clamp(1.3rem, 2vw, 1.6rem);
  font-weight: 800;
}

.dbc-section-head.compact .dbc-heading-accent {
  padding-bottom: 10px;
  margin-bottom: 0;
}

.dbc-section-head.compact .dbc-heading-accent::after {
  width: 40px;
  height: 2px;
}

.dbc-article-featured {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  box-shadow: 0 12px 32px rgba(23,20,18,.08);
  text-decoration: none;
  color: inherit;
  margin-bottom: 14px;
  transition: transform .25s ease, box-shadow .25s ease;
}

.dbc-article-featured:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 44px rgba(23,20,18,.14);
}

.dbc-article-featured-media {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #e9e1d8;
  overflow: hidden;
}

.dbc-article-featured-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}

.dbc-article-featured:hover .dbc-article-featured-media img {
  transform: scale(1.04);
}

.dbc-featured-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--dbc-gold);
  color: var(--dbc-ink);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .03em;
  text-transform: uppercase;
  box-shadow: 0 6px 18px rgba(23,20,18,.18);
}

.dbc-article-featured-body {
  padding: 18px 22px 20px;
}

.dbc-article-featured-body h3 {
  font-size: 1.25rem;
  font-weight: 850;
  margin: 0 0 .5rem;
  line-height: 1.3;
}

.dbc-article-featured-body p {
  color: #6c625c;
  margin-bottom: .7rem;
  line-height: 1.55;
}

.dbc-read-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 800;
  color: var(--dbc-clay);
  font-size: .92rem;
}

/* List card lebih kompak */
.dbc-list-card {
  padding: 14px 18px;
  margin-bottom: 10px;
  align-items: center;
  transition: transform .2s ease, border-color .2s ease;
}

.dbc-list-card:hover {
  transform: translateX(3px);
  border-color: var(--dbc-gold);
}

.dbc-list-card h3 {
  font-size: 1.02rem !important;
  margin: 0 0 .25rem !important;
  line-height: 1.35;
}

.dbc-list-card p {
  font-size: .88rem;
  margin: 0;
  line-height: 1.45;
}

.dbc-list-card i {
  flex-shrink: 0;
  font-size: 1.1rem;
}

/* Video grid — gradient overlay agar judul terbaca, auto-flow rapi */
.dbc-video-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.dbc-video-grid .dbc-video-card {
  margin-bottom: 0;
  border-radius: 10px;
  transition: transform .25s ease, box-shadow .25s ease;
}

.dbc-video-grid .dbc-video-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,.25);
}

.dbc-video-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,.85) 100%);
  z-index: 1;
  pointer-events: none;
}

.dbc-video-card span {
  z-index: 2;
  background: rgba(0,0,0,.18);
  transition: background .2s ease;
}

.dbc-video-card span i {
  font-size: 2.6rem;
  text-shadow: 0 4px 12px rgba(0,0,0,.5);
}

.dbc-video-card:hover span {
  background: rgba(0,0,0,.35);
}

.dbc-video-card strong {
  z-index: 2;
  font-size: .92rem;
  font-weight: 800;
  line-height: 1.3;
  text-shadow: 0 2px 6px rgba(0,0,0,.6);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 600px) {
  .dbc-video-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .dbc-hero {
    padding: 60px 0 48px;
  }
  .dbc-section,
  .dbc-about-section {
    padding: 48px 0;
  }
  .dbc-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .dbc-card-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== Tentang Kami — admin ===== */
.dbc-tentang-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}

.dbc-tentang-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 10px;
  overflow: hidden;
}

.dbc-tentang-thumb {
  aspect-ratio: 4 / 3;
  background: #e9e1d8;
}

.dbc-tentang-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.dbc-tentang-body {
  padding: 12px 14px 6px;
  flex: 1;
}

.dbc-tentang-body strong {
  display: block;
  font-size: .95rem;
  margin-bottom: 4px;
}

.dbc-tentang-body p {
  font-size: .85rem;
  color: #6c625c;
  margin: 0 0 6px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.dbc-tentang-actions {
  display: flex;
  gap: 6px;
  padding: 8px 12px 12px;
}

.dbc-tentang-preview {
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  border: 1px dashed rgba(23,20,18,.18);
  background: #f8f5f0;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.dbc-tentang-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ===== Tentang Kami — landing publik ===== */
.dbc-tentang-section {
  background: #faf7f1;
}

.dbc-tentang-group {
  margin-bottom: 36px;
}

.dbc-tentang-group:last-child {
  margin-bottom: 0;
}

.dbc-tentang-group-head {
  margin-bottom: 18px;
  padding-left: 14px;
  border-left: 4px solid var(--dbc-gold);
}

.dbc-tentang-group-title {
  font-size: 1.35rem;
  font-weight: 850;
  color: var(--dbc-warm-dark, #1b1410);
  margin: 0 0 4px;
}

.dbc-tentang-group-desc {
  font-size: .95rem;
  color: #6c625c;
  margin: 0;
  line-height: 1.55;
  max-width: 760px;
}

/* Magazine mosaic: featured + smaller items */
.dbc-tentang-public-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 14px;
}

.dbc-tentang-public-card {
  position: relative;
  margin: 0;
  overflow: hidden;
  border-radius: 4px;
  grid-column: span 2;
  background: #1b1410;
  isolation: isolate;
}

.dbc-tentang-public-card.featured {
  grid-column: span 4;
  grid-row: span 2;
}

.dbc-tentang-public-card img {
  width: 100%;
  height: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  transition: transform .8s cubic-bezier(.2,.7,.2,1), filter .4s ease;
}

.dbc-tentang-public-card.featured img {
  aspect-ratio: auto;
  min-height: 100%;
}

.dbc-tentang-public-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.78) 100%);
  z-index: 1;
  pointer-events: none;
  opacity: .7;
  transition: opacity .35s ease;
}

.dbc-tentang-public-card:hover::before {
  opacity: 1;
}

.dbc-tentang-public-card:hover img {
  transform: scale(1.06);
}

.dbc-tentang-public-card figcaption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 20px 22px;
  color: #fff;
  z-index: 2;
}

.dbc-tentang-public-card figcaption strong {
  display: block;
  font-size: 1rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: .01em;
  margin-bottom: 4px;
  text-shadow: 0 2px 8px rgba(0,0,0,.45);
}

.dbc-tentang-public-card.featured figcaption strong {
  font-size: 1.35rem;
  font-weight: 850;
}

.dbc-tentang-public-card figcaption p {
  font-size: .85rem;
  color: rgba(255,255,255,.82);
  line-height: 1.5;
  margin: 0;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .4s ease, opacity .3s ease, margin-top .3s ease;
}

.dbc-tentang-public-card:hover figcaption p {
  max-height: 8rem;
  opacity: 1;
  margin-top: 6px;
}

.dbc-tentang-public-card.featured figcaption p {
  font-size: .95rem;
}

@media (max-width: 900px) {
  .dbc-tentang-section {
    padding: 64px 0;
  }
  .dbc-tentang-group {
    margin-bottom: 48px;
    padding-bottom: 44px;
  }
  .dbc-tentang-public-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .dbc-tentang-public-card,
  .dbc-tentang-public-card.featured {
    grid-column: span 2;
    grid-row: auto;
  }
  /* Tampilkan caption permanen di tablet+mobile (tidak ada hover) */
  .dbc-tentang-public-card figcaption p {
    max-height: 8rem;
    opacity: 1;
    margin-top: 6px;
  }
  .dbc-tentang-public-card::before {
    opacity: 1;
  }
}

@media (max-width: 520px) {
  .dbc-tentang-public-grid {
    grid-template-columns: 1fr;
  }
  .dbc-tentang-public-card,
  .dbc-tentang-public-card.featured {
    grid-column: span 1;
  }
  .dbc-tentang-group-head {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

.dbc-page-hero {
  background: var(--dbc-ink);
  color: #fff;
  padding: 64px 0 48px;
}

.dbc-page-hero.compact {
  padding: 48px 0 36px;
}

.dbc-category-tabs {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 12px 0 20px;
  background: var(--dbc-paper);
}

.dbc-category-tabs a {
  white-space: nowrap;
  padding: 9px 14px;
  border: 1px solid rgba(23,20,18,.12);
  border-radius: 999px;
  color: var(--dbc-ink);
  text-decoration: none;
  background: #fff;
  font-weight: 700;
}

.dbc-menu-group {
  scroll-margin-top: 80px;
  margin-top: 26px;
}

.dbc-related-links {
  border-top: 1px solid rgba(23,20,18,.08);
  margin-top: 16px;
  padding-top: 12px;
  display: grid;
  gap: 8px;
}

.dbc-related-links a,
.dbc-related-links button {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--dbc-sage);
  text-align: left;
  font-weight: 700;
  text-decoration: none;
}

.dbc-article-cover {
  max-height: 460px;
  border-radius: 8px;
  margin-bottom: 24px;
}

.dbc-article-body {
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 8px;
  padding: 28px;
  font-size: 1.05rem;
  line-height: 1.75;
}

/* KPI Card untuk laporan keuntungan */
.dbc-kpi-card {
  background: #fff;
  border-radius: 10px;
  padding: 14px 16px;
  border: 1px solid rgba(23,20,18,.08);
  border-left: 4px solid #0d6efd;
  height: 100%;
}

.dbc-kpi-card span {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 700;
  color: #6c625c;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 6px;
}

.dbc-kpi-card span i {
  font-size: 1.1rem;
  color: #0d6efd;
}

.dbc-kpi-card strong {
  display: block;
  font-size: 1.35rem;
  font-weight: 850;
  color: var(--dbc-warm-dark, #1b1410);
  line-height: 1.2;
}

.dbc-kpi-card small {
  display: block;
  font-size: .75rem;
  color: #6c625c;
  margin-top: 4px;
}

.dbc-kpi-card.success { border-left-color: #2e9e6b; }
.dbc-kpi-card.success span i { color: #2e9e6b; }

.dbc-kpi-card.warning { border-left-color: #f0a000; }
.dbc-kpi-card.warning span i { color: #f0a000; }

.dbc-kpi-card.danger { border-left-color: #dc3545; }
.dbc-kpi-card.danger span i { color: #dc3545; }

/* Laba bersih: alur perhitungan Profit − Beban = Laba */
.dbc-net-flow {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  align-items: stretch;
  gap: 12px;
}

.dbc-net-item {
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 10px;
  padding: 14px 16px;
}

.dbc-net-item span {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 700;
  color: #6c625c;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 6px;
}

.dbc-net-item strong {
  display: block;
  font-size: 1.35rem;
  font-weight: 850;
  color: var(--dbc-warm-dark, #1b1410);
  line-height: 1.2;
}

.dbc-net-op {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 800;
  color: #b3aaa2;
}

.dbc-net-result {
  background: linear-gradient(180deg, #f1f8ff 0%, #ffffff 100%);
  border-color: rgba(13,110,253,.25);
  box-shadow: 0 6px 18px rgba(13,110,253,.08);
}

.dbc-net-result span { color: #0d6efd; }
.dbc-net-result strong { color: #0d6efd; }
.dbc-net-result.is-negative {
  background: linear-gradient(180deg, #fff5f5 0%, #ffffff 100%);
  border-color: rgba(220,53,69,.25);
  box-shadow: none;
}
.dbc-net-result.is-negative span,
.dbc-net-result.is-negative strong { color: #dc3545; }

/* Pemisah & kartu pihak bagi hasil */
.dbc-share-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 18px 0 12px;
  color: #6c625c;
  font-weight: 700;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.dbc-share-divider::before,
.dbc-share-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(23,20,18,.1);
}

.dbc-share-party {
  display: flex;
  align-items: center;
  gap: 14px;
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 12px;
  padding: 16px 18px;
  height: 100%;
}

.dbc-share-party-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  flex-shrink: 0;
}
.dbc-share-party.owner .dbc-share-party-icon { background: #e9f6ef; color: #2e9e6b; }
.dbc-share-party.manager .dbc-share-party-icon { background: #eef4ff; color: #0d6efd; }

.dbc-share-party-body { min-width: 0; }

.dbc-share-party-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 800;
  color: var(--dbc-warm-dark, #1b1410);
  margin-bottom: 2px;
}

.dbc-share-pct {
  font-size: .72rem;
  font-weight: 800;
  padding: 2px 9px;
  border-radius: 999px;
}
.dbc-share-party.owner .dbc-share-pct { background: rgba(46,158,107,.14); color: #2e9e6b; }
.dbc-share-party.manager .dbc-share-pct { background: rgba(13,110,253,.12); color: #0d6efd; }

.dbc-share-amount {
  font-size: 1.5rem;
  font-weight: 850;
  color: var(--dbc-warm-dark, #1b1410);
  line-height: 1.2;
}

.dbc-share-empty {
  background: #faf7f1;
  border: 1px dashed rgba(23,20,18,.18);
  border-radius: 10px;
  padding: 12px 14px;
  color: #6c625c;
  font-size: .9rem;
}

@media (max-width: 640px) {
  .dbc-net-flow {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .dbc-net-op { transform: rotate(90deg); }
}

/* Halaman "Datang ke dBasecamp" */
.dbc-datang-hero {
  padding: 80px 0 64px;
  background: linear-gradient(180deg, #faf7f1 0%, #ffffff 100%);
}

.dbc-datang-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, .9fr);
  gap: 40px;
  align-items: start;
}

.dbc-datang-copy h1 {
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 850;
  line-height: 1.1;
  margin: 8px 0 14px;
  color: var(--dbc-warm-dark, #1b1410);
}

.dbc-datang-copy .lead {
  font-size: 1.1rem;
  color: #5d554f;
  line-height: 1.65;
}

.dbc-datang-steps {
  margin-top: 32px;
  display: grid;
  gap: 16px;
}

.dbc-datang-step {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 16px;
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 10px;
  box-shadow: 0 4px 14px rgba(23,20,18,.04);
}

.dbc-step-num {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--dbc-gold, #cba258);
  color: #1b1410;
  display: grid;
  place-items: center;
  font-weight: 900;
  font-size: 1.1rem;
}

.dbc-datang-step strong {
  display: block;
  font-size: 1.05rem;
  margin-bottom: 4px;
  color: var(--dbc-warm-dark, #1b1410);
}

.dbc-datang-step p {
  font-size: .92rem;
  color: #6c625c;
  margin: 0;
  line-height: 1.5;
}

.dbc-datang-info {
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 8px 24px rgba(23,20,18,.06);
  position: sticky;
  top: 20px;
}

.dbc-datang-info h3 {
  font-size: 1.15rem;
  font-weight: 800;
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--dbc-gold, #cba258);
}

.dbc-info-row {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid rgba(23,20,18,.06);
}

.dbc-info-row:last-of-type {
  border-bottom: 0;
}

.dbc-info-row i {
  font-size: 1.3rem;
  color: var(--dbc-gold, #cba258);
  margin-top: 2px;
}

.dbc-info-row small {
  display: block;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #6c625c;
  font-weight: 700;
}

.dbc-info-row strong {
  display: block;
  font-size: .98rem;
  color: var(--dbc-warm-dark, #1b1410);
}

.dbc-info-row strong a {
  color: inherit;
  text-decoration: none;
}

.dbc-datang-map {
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid rgba(23,20,18,.08);
  aspect-ratio: 4 / 3;
}

.dbc-datang-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (max-width: 900px) {
  .dbc-datang-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .dbc-datang-info {
    position: static;
  }
}

/* Panel anomali dashboard owner */
.dbc-anomali-panel {
  background: #fff8e6;
  border: 1px solid rgba(240,160,0,.3);
  border-radius: 12px;
  padding: 18px;
}

.dbc-anomali-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-left: 4px solid #f0a000;
  text-decoration: none;
  color: inherit;
  height: 100%;
  transition: transform .2s ease, box-shadow .2s ease;
}

.dbc-anomali-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(23,20,18,.1);
  color: inherit;
}

.dbc-anomali-card i {
  font-size: 1.5rem;
  color: #f0a000;
  flex-shrink: 0;
}

.dbc-anomali-card.is-danger {
  border-left-color: #dc3545;
}
.dbc-anomali-card.is-danger i {
  color: #dc3545;
}

.dbc-anomali-card.is-info {
  border-left-color: #0d6efd;
}
.dbc-anomali-card.is-info i {
  color: #0d6efd;
}

.dbc-anomali-card strong {
  display: block;
  font-size: .92rem;
  margin-bottom: 2px;
}

.dbc-anomali-card p {
  font-size: .82rem;
  color: #6c625c;
  margin: 0;
  line-height: 1.4;
}

/* Live indicator (auto-refresh kasir) */
.dbc-live-indicator {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(23,20,18,.06);
  font-size: .82rem;
  font-weight: 700;
  color: #5d554f;
}

.dbc-live-indicator .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #888;
}

.dbc-live-indicator.is-live .dot {
  background: #2e9e6b;
  box-shadow: 0 0 0 0 rgba(46,158,107,.6);
  animation: dbc-pulse 1.6s infinite;
}

.dbc-live-indicator.is-live {
  background: rgba(46,158,107,.12);
  color: #1f7a52;
}

.dbc-live-indicator.is-stale {
  background: rgba(203,162,88,.18);
  color: #8a6512;
}

.dbc-live-indicator.is-stale .dot {
  background: #cba258;
}

.dbc-live-indicator.is-offline {
  background: rgba(220,53,69,.12);
  color: #b02a37;
}

.dbc-live-indicator.is-offline .dot {
  background: #dc3545;
}

@keyframes dbc-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(46,158,107,.6); }
  70%  { box-shadow: 0 0 0 8px rgba(46,158,107,0); }
  100% { box-shadow: 0 0 0 0 rgba(46,158,107,0); }
}

/* === Panel pesanan dibatalkan hari ini === */
.dbc-cancelled-panel {
  margin-top: 12px;
  border: 1px solid rgba(220,53,69,.18);
  border-radius: 10px;
  background: #fff7f8;
  padding: 0;
}

.dbc-cancelled-panel > summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  font-size: .95rem;
  user-select: none;
}

.dbc-cancelled-panel > summary::-webkit-details-marker {
  display: none;
}

.dbc-cancelled-panel[open] > summary {
  border-bottom: 1px solid rgba(220,53,69,.14);
}

.dbc-cancelled-panel > summary i:first-child {
  color: #dc3545;
  font-size: 1.2rem;
}

.dbc-cancelled-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  padding: 0 18px 18px;
}

.dbc-cancelled-card {
  background: #fff;
  border: 1px solid rgba(220,53,69,.16);
  border-radius: 8px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dbc-cancelled-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.dbc-queue-number.sm {
  min-width: 52px;
  padding: 6px 8px;
}

.dbc-queue-number.sm strong {
  font-size: 1.3rem;
}

.dbc-cancelled-reason {
  background: rgba(220,53,69,.06);
  border-left: 3px solid #dc3545;
  padding: 6px 10px;
  border-radius: 4px;
  font-size: .85rem;
  color: #5d2b30;
}

.dbc-cancelled-reason i {
  color: #dc3545;
  margin-right: 4px;
}

/* === Produksi: badge & urgency === */
.dbc-qty-pill {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  background: rgba(23,20,18,.06);
  color: #5d554f;
  font-size: .8rem;
  font-weight: 800;
  white-space: nowrap;
}

.dbc-customer-name {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 4px 0;
  padding: 3px 10px;
  border-radius: 6px;
  background: rgba(203,162,88,.18);
  color: #6b4d18;
  font-weight: 800;
  font-size: .92rem;
}

.dbc-customer-name i {
  color: #cba258;
}

.dbc-call-name {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--dbc-gold, #cba258);
  margin: 8px 0 4px;
}

.dbc-wait-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 6px;
  background: rgba(23,20,18,.05);
  color: #5d554f;
  font-weight: 700;
}

.dbc-production-card.is-warning {
  background: linear-gradient(180deg, #fff8e6, #fff);
  border-left: 4px solid #f0a000;
}

.dbc-production-card.is-warning .dbc-wait-badge {
  background: rgba(240,160,0,.18);
  color: #8a5a00;
}

.dbc-production-card.is-urgent {
  background: linear-gradient(180deg, #ffe5e8, #fff);
  border-left: 4px solid #dc3545;
  animation: dbc-urgent-pulse 2s ease-in-out infinite;
}

.dbc-production-card.is-urgent .dbc-wait-badge {
  background: rgba(220,53,69,.18);
  color: #a02333;
  font-weight: 900;
}

@keyframes dbc-urgent-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220,53,69,.0); }
  50%      { box-shadow: 0 0 0 6px rgba(220,53,69,.12); }
}

.dbc-article-lead {
  background: rgba(225, 179, 105, .14);
  border-left: 4px solid var(--dbc-gold);
  border-radius: 8px;
  color: var(--dbc-ink);
  font-size: 1.1rem;
  line-height: 1.7;
  margin: 0 0 18px;
  padding: 18px 20px;
}

.dbc-article-body h2,
.dbc-article-body h3,
.dbc-article-body h4 {
  margin: 1.4em 0 .55em;
  font-weight: 900;
}

.dbc-article-body p,
.dbc-article-body ul,
.dbc-article-body ol,
.dbc-article-body blockquote,
.dbc-article-body table,
.dbc-article-body figure {
  margin-bottom: 1rem;
}

.dbc-article-body a {
  color: var(--dbc-sage);
  font-weight: 750;
}

.dbc-article-body img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

.dbc-article-body blockquote {
  padding: 14px 16px;
  border-left: 4px solid var(--dbc-gold);
  border-radius: 8px;
  background: #f7f2ea;
}

.dbc-article-body table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 8px;
}

.dbc-article-body th,
.dbc-article-body td {
  border: 1px solid rgba(23,20,18,.12);
  padding: 10px;
  vertical-align: top;
}

.dbc-article-body th {
  background: #eef2ee;
}

.dbc-side-panel {
  padding: 18px;
  margin-bottom: 16px;
}

.dbc-side-image {
  aspect-ratio: 16 / 10;
  border-radius: 8px;
  margin-bottom: 14px;
}

.dbc-side-link {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(23,20,18,.08);
  text-decoration: none;
  color: var(--dbc-ink);
  font-weight: 700;
}

.dbc-empty {
  border: 1px dashed rgba(23,20,18,.22);
  border-radius: 8px;
  padding: 28px;
  background: #fff;
  color: #6c625c;
}

.dbc-public-footer {
  background: var(--dbc-ink);
  color: #fff;
  padding: 42px 0;
}

.dbc-footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  font-size: 1.35rem;
  font-weight: 900;
}

.dbc-footer-title {
  color: #fff;
  font-weight: 850;
  margin-bottom: 12px;
}

.dbc-footer-links {
  display: grid;
  gap: 9px;
}

.dbc-footer-links a {
  color: rgba(255,255,255,.68);
  text-decoration: none;
  font-weight: 650;
}

.dbc-footer-links a:hover {
  color: #fff;
}

.dbc-public-footer .dbc-social-link {
  width: 42px;
  height: 42px;
  padding: 0;
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: #fff;
}

.dbc-public-footer .dbc-social-link:hover {
  background: var(--dbc-gold);
  color: var(--dbc-ink);
}

.dbc-public-footer .dbc-social-link span {
  display: none;
}

.dbc-footer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 12px;
  color: rgba(255,255,255,.68);
}

.dbc-footer-info {
  display: grid;
  gap: 12px;
}

.dbc-footer-info div {
  display: flex;
  gap: 10px;
  color: rgba(255,255,255,.7);
  line-height: 1.5;
}

.dbc-footer-info i {
  flex: 0 0 22px;
  color: var(--dbc-gold);
  font-size: 1.15rem;
  margin-top: 2px;
}

.dbc-login-page {
  min-height: 100vh;
  background: var(--dbc-paper);
}

.dbc-login-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(440px, .72fr);
}

.dbc-login-brand {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 44px;
  background: linear-gradient(135deg, rgba(11,42,36,.98), rgba(30,57,50,.94));
  color: #fff;
}

.dbc-login-logo {
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-weight: 900;
  font-size: 1.6rem;
}

.dbc-login-logo span {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--dbc-gold);
  color: var(--dbc-ink);
}

.dbc-login-copy {
  max-width: 720px;
  padding: 72px 0;
}

.dbc-login-copy h1 {
  font-size: clamp(2.4rem, 5vw, 4.8rem);
  line-height: 1;
  font-weight: 900;
  margin: .6rem 0 1rem;
  color: #fff;
}

.dbc-login-stats strong {
  color: #fff;
}

.dbc-login-copy p {
  max-width: 620px;
  color: rgba(255,255,255,.72);
  font-size: 1.08rem;
}

.dbc-login-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.dbc-login-stats div {
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  padding: 14px;
  background: rgba(255,255,255,.06);
}

.dbc-login-stats span {
  display: block;
  color: rgba(255,255,255,.58);
  font-size: .78rem;
}

.dbc-login-stats strong {
  display: block;
  margin-top: 4px;
}

.dbc-login-panel {
  display: grid;
  align-items: center;
  padding: 36px;
}

.dbc-login-card {
  width: min(100%, 520px);
  margin: 0 auto;
  background: #fff;
  border: 1px solid rgba(23,20,18,.08);
  border-radius: 8px;
  padding: 28px;
  box-shadow: 0 24px 80px rgba(23,20,18,.1);
}

.dbc-login-card-head {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 16px;
  margin-bottom: 20px;
}

.dbc-login-card-head h2 {
  margin: .2rem 0 0;
  font-size: 2rem;
  font-weight: 900;
}

.dbc-demo-login {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 18px;
}

.dbc-demo-login button {
  border: 1px solid rgba(23,20,18,.12);
  border-radius: 8px;
  background: #fbfaf7;
  padding: 12px;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 10px;
  text-align: left;
  color: var(--dbc-ink);
}

.dbc-demo-login i {
  grid-row: span 2;
  color: var(--dbc-clay);
  font-size: 1.4rem;
}

.dbc-demo-login span {
  font-weight: 800;
}

.dbc-demo-login small {
  color: #6c625c;
}

.dbc-login-links {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
}

.dbc-login-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  border-radius: 8px;
  background: var(--tblr-primary-lt);
  color: var(--dbc-warm-dark);
  text-decoration: none;
  font-weight: 800;
}

@media (max-width: 991px) {
  .dbc-stat-grid,
  .dbc-stat-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dbc-kasir-widget-grid,
  .dbc-kasir-order-grid,
  .dbc-kasir-detail-grid {
    grid-template-columns: 1fr;
  }

  .dbc-kasir-payment-panel {
    position: static;
  }

  .dbc-admin-toolbar,
  .dbc-table-card .card-header,
  .dbc-stock-alert-panel,
  .dbc-kasir-head,
  .dbc-kasir-detail-head,
  .dbc-production-head {
    align-items: stretch;
    flex-direction: column;
  }

  .dbc-stock-alert-panel {
    display: flex;
  }

  .dbc-stock-alert-list {
    grid-template-columns: 1fr;
  }

  .dbc-production-summary,
  .dbc-production-board {
    grid-template-columns: 1fr;
  }

  .dbc-production-column {
    min-height: auto;
  }

  .dbc-settings-layout {
    grid-template-columns: 1fr;
  }

  .dbc-settings-side {
    position: static;
  }

  .dbc-admin-toolbar .btn,
  .dbc-table-card .card-header .input-icon,
  .dbc-table-card .card-header .btn {
    width: 100%;
  }

  .dbc-hero-grid,
  .dbc-about-grid,
  .dbc-location-grid,
  .dbc-card-grid,
  .dbc-article-grid {
    grid-template-columns: 1fr;
  }

  .dbc-location-map {
    min-height: 280px;
  }

  .dbc-login-shell {
    grid-template-columns: 1fr;
  }

  .dbc-login-brand {
    min-height: auto;
    padding: 28px;
  }

  .dbc-login-copy {
    padding: 38px 0 24px;
  }

  .dbc-login-stats {
    grid-template-columns: 1fr;
  }

  .dbc-hero {
    padding: 64px 0 44px;
  }

  .dbc-hero-board {
    min-height: 260px;
  }
}

@media (max-width: 575px) {
  .dbc-stat-grid,
  .dbc-stat-grid.compact {
    grid-template-columns: 1fr;
  }

  .dbc-next-payment,
  .dbc-kasir-order-top {
    grid-template-columns: 1fr;
  }

  .dbc-kasir-order-body {
    grid-template-columns: 1fr;
  }

  .dbc-kasir-order-actions {
    grid-template-columns: 1fr;
  }

  .dbc-next-payment .btn,
  .dbc-kasir-order-actions .btn {
    width: 100%;
  }

  .dbc-admin-toolbar {
    padding: 14px;
  }

  .dbc-stat-card {
    min-height: 100px;
  }

  .dbc-section {
    padding: 42px 0;
  }

  .dbc-section-head {
    align-items: start;
    flex-direction: column;
  }

  .dbc-article-body {
    padding: 18px;
  }

  .dbc-social-form-grid {
    grid-template-columns: 1fr;
  }

  .dbc-settings-actions,
  .dbc-admin-toolbar > .d-flex {
    align-items: stretch;
    flex-direction: column;
  }

  .dbc-settings-actions .btn,
  .dbc-admin-toolbar > .d-flex .btn {
    width: 100%;
  }

  .dbc-login-panel {
    padding: 18px;
  }

  .dbc-login-card {
    padding: 20px;
  }

  .dbc-demo-login,
  .dbc-login-links {
    grid-template-columns: 1fr;
  }
}
