@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&display=swap');

/* ─── Custom properties ───────────────────────────────────────── */
:root {
  --dw-dark:        #283838;
  --dw-dark-2:      #1e2c2c;
  --dw-orange:      #EE7620;
  --dw-orange-2:    #d4661a;
  --dw-orange-soft: rgba(238,118,32,.10);
  --dw-sidebar-w:   260px;
  --dw-topbar-h:    58px;
  --bs-font-sans-serif: 'Montserrat', sans-serif;
  --bs-body-font-family: 'Montserrat', sans-serif;
  --bs-body-font-size: 14px;
  --bs-body-color: #283838;
  --bs-body-bg: #f3f4f2;
  --bs-primary: #EE7620;
  --bs-primary-rgb: 238,118,32;
}
*, *::before, *::after { box-sizing: border-box; }
body { font-family: 'Montserrat', sans-serif; }
.bx { vertical-align: -0.15em; line-height: 1; }
.cursor-pointer { cursor: pointer; }

/* ─── Bootstrap button overrides ─────────────────────────────── */
.btn-primary, .btn-dw-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--dw-orange);
  --bs-btn-border-color: var(--dw-orange);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--dw-orange-2);
  --bs-btn-hover-border-color: var(--dw-orange-2);
  --bs-btn-active-bg: #c05d17;
  --bs-btn-focus-shadow-rgb: 238,118,32;
  --bs-btn-disabled-bg: var(--dw-orange);
  --bs-btn-disabled-border-color: var(--dw-orange);
}
.btn-dw-dark {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--dw-dark);
  --bs-btn-border-color: var(--dw-dark);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--dw-dark-2);
  --bs-btn-hover-border-color: var(--dw-dark-2);
  --bs-btn-active-bg: #161f1f;
}
.btn-dw-success {
  --bs-btn-color: #fff;
  --bs-btn-bg: #3aaa6a;
  --bs-btn-border-color: #3aaa6a;
  --bs-btn-hover-bg: #2e9459;
  --bs-btn-hover-color: #fff;
}

/* ─── Colour helpers ──────────────────────────────────────────── */
.dw-text-primary { color: var(--dw-orange) !important; }
.dw-text-dark    { color: var(--dw-dark)   !important; }
.dw-bg-dark      { background-color: var(--dw-dark) !important; }

/* ─── Custom badges ───────────────────────────────────────────── */
.badge-dw-success { background-color: rgba(58,170,106,.15); color:#2a8a52; font-weight:700; }
.badge-dw-warning { background-color: rgba(238,118,32,.15); color:var(--dw-orange-2); font-weight:700; }
.badge-dw-danger  { background-color: rgba(220,53,69,.12);  color:#b02a37; font-weight:700; }
.badge-dw-orange  { background-color: var(--dw-orange); color:#fff; }
.badge-dw-erp     { background-color: rgba(100,120,130,.12); color:#7a9099; font-weight:600; }

.einheit-badge {
  font-size: 11px; font-weight: 600;
  background: #eef0ed; color: #5a6e6c;
  padding: 2px 8px; border-radius: 4px;
  white-space: nowrap;
}

/* ─── Login ───────────────────────────────────────────────────── */
#view-login {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background: var(--dw-dark);
  background-image:
    radial-gradient(circle at 15% 85%, rgba(238,118,32,.18) 0%, transparent 55%),
    radial-gradient(circle at 85% 15%, rgba(238,118,32,.10) 0%, transparent 50%);
}
.login-card { width: 420px; border-radius: 18px; box-shadow: 0 28px 80px rgba(0,0,0,.35); animation: fadeUp .45s ease both; }
.login-logo-mark { width:64px; height:64px; background:var(--dw-dark); border-radius:14px; display:flex; align-items:center; justify-content:center; }

/* ─── Shared Topbar ───────────────────────────────────────────── */
.dw-navbar {
  height: var(--dw-topbar-h);
  background: var(--dw-dark);
  padding: 0 20px;
  position: fixed; top:0; left:0; right:0;
  z-index: 1040;
  display: flex; align-items: center; gap: 14px;
  box-shadow: 0 2px 12px rgba(0,0,0,.22);
}
.dw-navbar-brand { font-size:16px; font-weight:800; color:#fff; letter-spacing:-.3px; flex-shrink:0; cursor:pointer; }
.dw-navbar-brand span { color: var(--dw-orange); }
.dw-navbar-brand:hover span { text-decoration: underline; }
.dw-navbar-sep { width:1px; height:26px; background:rgba(255,255,255,.12); flex-shrink:0; }

.dw-navbar-lager { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.dw-navbar-lager label { font-size:11px; color:rgba(255,255,255,.5); font-weight:600; white-space:nowrap; }
.dw-navbar-lager select {
  background:rgba(255,255,255,.08); border:1.5px solid rgba(255,255,255,.14);
  color:#fff; font-family:'Montserrat',sans-serif; font-size:12px; font-weight:600;
  padding:4px 10px; border-radius:6px; cursor:pointer;
}
.dw-navbar-lager select option { background: var(--dw-dark); }

.dw-search-wrap { position:relative; flex:1; max-width:380px; }
.dw-search-wrap input {
  width:100%; padding:7px 38px 7px 36px; border-radius:20px;
  border:1.5px solid rgba(255,255,255,.12); background:rgba(255,255,255,.07);
  color:#fff; font-family:'Montserrat',sans-serif; font-size:13px;
}
.dw-search-wrap input::placeholder { color:rgba(255,255,255,.30); }
.dw-search-wrap input:focus { outline:none; border-color:var(--dw-orange); background:rgba(255,255,255,.10); }
.dw-search-icon  { position:absolute; left:11px; top:50%; transform:translateY(-50%); color:rgba(255,255,255,.35); font-size:16px; line-height:1; pointer-events:none; }
.dw-search-hint  { position:absolute; right:11px; top:50%; transform:translateY(-50%); font-size:10px; color:rgba(255,255,255,.22); font-weight:600; pointer-events:none; }

.dw-navbar-btn {
  background:rgba(255,255,255,.07); border:1.5px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.75); border-radius:8px; padding:9px 14px;
  font-family:'Montserrat',sans-serif; font-size:12px; font-weight:600;
  display:flex; align-items:center; gap:6px;
  cursor:pointer; transition:all .15s; flex-shrink:0;
}
.dw-navbar-btn:hover  { background:rgba(255,255,255,.13); color:#fff; }
.dw-navbar-btn.active { background:var(--dw-orange); border-color:var(--dw-orange); color:#fff; }
.dw-navbar-btn .bx   { font-size:16px; }
.dw-navbar-btn .badge { background:#dc3545 !important; color:#fff !important; }

.dw-user-chip   { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.dw-user-avatar { width:32px; height:32px; background:var(--dw-orange); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:800; color:#fff; }
.dw-user-name   { font-size:12px; font-weight:700; color:#fff; line-height:1.2; }
.dw-user-kdnr   { font-size:10px; color:rgba(255,255,255,.45); }

/* ─── App shell layout ────────────────────────────────────────── */
#app-shell { padding-top: var(--dw-topbar-h); display:flex; min-height:100vh; }

.dw-sidebar {
  width: var(--dw-sidebar-w);
  flex-shrink: 0;
  background: #fff;
  border-right: 1px solid #dee2e6;
  position: fixed;
  top: var(--dw-topbar-h); left:0; bottom:0;
  overflow-y: auto; overflow-x: hidden;
}
.dw-sidebar::-webkit-scrollbar { width:4px; }
.dw-sidebar::-webkit-scrollbar-thumb { background:#ccd; border-radius:2px; }

#app-main {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
}

.dw-main-content { padding: 22px 24px; flex: 1; }

/* Sidebar labels & nav */
.sidebar-section-label { font-size:10px; font-weight:700; letter-spacing:.7px; text-transform:uppercase; color:#9aabaa; padding:14px 16px 6px; }
.sidebar-divider { height:1px; background:#e9ecef; margin:8px 14px; }

.cat-parent {
  border:none; border-radius:0;
  font-family:'Montserrat',sans-serif; font-size:13px; font-weight:600;
  color:var(--dw-dark); background:transparent;
  border-left:3px solid transparent;
  transition:background .15s, color .15s;
}
.cat-parent:hover, .cat-parent:focus { background:#f0f2f0; color:var(--dw-dark); }
.cat-parent-active { color:var(--dw-orange) !important; background:var(--dw-orange-soft) !important; border-left-color:var(--dw-orange) !important; }
.cat-chevron { font-size:16px; color:#bbb; transition:transform .22s ease; }

.cat-children { background:#fafbfa; }
.cat-sub {
  font-family:'Montserrat',sans-serif; font-size:12.5px; font-weight:500;
  color:#6c7a79; border:none; border-radius:0;
  border-left:3px solid transparent;
  transition:background .12s, color .12s; background:transparent;
}
.cat-sub:hover { background:#eef0ed; color:var(--dw-dark); }
.cat-sub.active { color:var(--dw-orange); font-weight:700; background:var(--dw-orange-soft); border-left-color:var(--dw-orange); }

/* ─── Select2 overrides ───────────────────────────────────────── */
.select2-container--default .select2-selection--single {
  height: 38px; border: 1px solid #ced4da; border-radius: 6px; background:#fff;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 36px; font-family:'Montserrat',sans-serif; font-size:13.5px; color:var(--dw-dark); padding-left:12px;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 36px;
}
.select2-container--default .select2-selection--single .select2-selection__placeholder {
  color:#aaa;
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--dw-orange); outline:none; box-shadow:0 0 0 .2rem rgba(238,118,32,.20);
}
.select2-container--default .select2-results__option--highlighted {
  background-color: var(--dw-orange) !important;
}
.select2-container--default .select2-results__option--selected {
  background-color: var(--dw-orange-soft); color: var(--dw-dark);
}
.select2-search--dropdown {
  padding: 8px 10px;
  background: #f8f9f8;
  border-bottom: 1px solid #e5e8e3;
}
.select2-search--dropdown .select2-search__field {
  font-family: 'Montserrat', sans-serif; font-size: 13px;
  border: 1.5px solid #ced4da; border-radius: 6px;
  padding: 6px 10px; outline: none;
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='2.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat 8px center;
  padding-left: 28px;
}
.select2-search--dropdown .select2-search__field:focus {
  border-color: var(--dw-orange); box-shadow: 0 0 0 .15rem rgba(238,118,32,.18);
}
.select2-dropdown {
  border-color: #ced4da; border-radius: 8px;
  box-shadow: 0 6px 24px rgba(0,0,0,.12);
  overflow: hidden;
}
.select2-results__options { padding: 4px 0; }
.select2-results__option {
  font-family: 'Montserrat', sans-serif; font-size: 13px; padding: 7px 12px;
}

/* ─── Breadcrumb ──────────────────────────────────────────────── */
.breadcrumb { font-size:12px; font-weight:500; --bs-breadcrumb-divider:'›'; }
.breadcrumb-item a { color:var(--dw-orange); }
.breadcrumb-item.active { color:var(--dw-dark); font-weight:700; }

/* Search scope indicator */
#search-scope {
  font-size:11px; font-weight:700; letter-spacing:.4px;
  background:rgba(238,118,32,.10); color:var(--dw-orange-2);
  padding:2px 10px; border-radius:20px;
}

/* ─── Products table ──────────────────────────────────────────── */
.products-header h2 { font-size:18px; font-weight:800; letter-spacing:-.3px; }

.table-dw thead th {
  background:var(--dw-dark); color:#fff;
  font-size:11px; font-weight:700; letter-spacing:.5px; text-transform:uppercase;
  white-space:nowrap; vertical-align:middle; border:none;
}
.table-dw tbody td { vertical-align:middle; border-color:#eef0ed; background:#fff; white-space:nowrap; }
.table-dw tbody td:nth-child(2) { white-space:normal; }
.table-dw tbody tr:hover td { background:#f8faf7; }
.row-in-cart td:first-child { border-left:3px solid #3aaa6a; }
.row-in-cart { background:rgba(58,170,106,.04) !important; }

/* ─── Qty control (shared: table + cart) ─────────────────────── */
.dw-qty {
  display: inline-flex;
  align-items: center;
  border: 1.5px solid #d0d8d6;
  border-radius: 7px;
  overflow: hidden;
  background: #fff;
}
.dw-qty button {
  width: 30px; height: 30px;
  border: none; background: transparent;
  color: var(--dw-dark); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  transition: background .12s, color .12s;
  flex-shrink: 0;
}
.dw-qty button:hover { background: var(--dw-dark); color: #fff; }
.dw-qty input {
  width: 46px; height: 30px;
  border: none;
  border-left: 1.5px solid #d0d8d6;
  border-right: 1.5px solid #d0d8d6;
  text-align: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 700;
  color: var(--dw-dark);
  background: #fff;
  outline: none;
}
.dw-qty input:focus { border-color: var(--dw-orange); }
.dw-qty input::-webkit-inner-spin-button,
.dw-qty input::-webkit-outer-spin-button { -webkit-appearance:none; }
.dw-qty input[type=number] { -moz-appearance:textfield; }

/* Smaller variant for cart offcanvas */
.dw-qty-sm button { width:24px; height:24px; font-size:12px; }
.dw-qty-sm input  { width:36px; height:24px; font-size:11px; }

/* ─── Cart offcanvas ──────────────────────────────────────────── */
.offcanvas.dw-cart { width:380px; }
.dw-cart .offcanvas-header { background:var(--dw-dark); color:#fff; padding:12px 18px; }
.dw-cart .offcanvas-title  { font-size:15px; font-weight:800; }
.dw-cart .btn-close        { filter:invert(1); }

.cart-item { background:#fff; border:1.5px solid #e5e8e4; }
.cart-item-nr    { font-size:10px; font-weight:700; letter-spacing:.4px; color:#9aabaa; text-transform:uppercase; margin-bottom:2px; }
.cart-item-title { font-size:12.5px; line-height:1.3; }
.cart-remove-btn { border:none; background:transparent; color:#bbb; padding:2px 4px; border-radius:4px; cursor:pointer; font-size:16px; line-height:1; transition:color .12s; }
.cart-remove-btn:hover { color:#dc3545; }
.cart-total-line { font-size:15px; font-weight:800; }

/* ─── Checkout layout ─────────────────────────────────────────── */
.checkout-wrap { padding: 28px 24px; max-width: 1080px; margin: 0 auto; }
.checkout-grid { display:grid; grid-template-columns:1fr 340px; gap:24px; align-items:start; }
.checkout-sticky { position:sticky; top:calc(var(--dw-topbar-h) + 16px); }

.checkout-section-num {
  width:24px; height:24px; background:var(--dw-dark); color:#fff;
  border-radius:50%; display:inline-flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:800;
}

.dw-delivery-tabs { display:flex; border-radius:10px; overflow:hidden; border:1.5px solid #dee2e6; background:#fff; }
.dw-delivery-tab {
  flex:1; padding:12px 14px; background:transparent; border:none;
  font-family:'Montserrat',sans-serif; font-size:12.5px; font-weight:700; color:#8a9b99;
  cursor:pointer; display:flex; flex-direction:column; align-items:center; gap:4px; transition:all .18s;
}
.dw-delivery-tab:not(:last-child) { border-right:1.5px solid #dee2e6; }
.dw-delivery-tab.active { background:var(--dw-dark); color:#fff; }
.dw-delivery-tab .bx { font-size:22px; }

.lager-cards { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.lager-card  { border:2px solid #dee2e6 !important; transition:border-color .15s; }
.lager-card:hover { border-color:var(--dw-dark) !important; }
.lager-card.selected { border-color:var(--dw-orange) !important; background:var(--dw-orange-soft); }

.bv-card  { border:2px solid #dee2e6 !important; transition:border-color .15s; }
.bv-card:hover  { border-color:var(--dw-dark) !important; }
.bv-card.selected { border-color:var(--dw-orange) !important; background:var(--dw-orange-soft); }
.bv-radio { width:18px; height:18px; border-radius:50%; border:2px solid #ccc; transition:all .15s; }
.bv-radio.selected { border-color:var(--dw-orange); background:radial-gradient(circle,var(--dw-orange) 45%,transparent 46%); }

.bv-add-btn { border:2px dashed #ccc; border-radius:10px; padding:12px; text-align:center; color:#9aabaa; font-size:13px; font-weight:600; cursor:pointer; transition:all .15s; display:flex; align-items:center; justify-content:center; gap:8px; }
.bv-add-btn:hover { border-color:var(--dw-orange); color:var(--dw-orange); }

.liefertyp-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.liefertyp-card { border:2px solid #dee2e6 !important; transition:border-color .15s; }
.liefertyp-card:hover { border-color:var(--dw-dark) !important; }
.liefertyp-card.selected { border-color:var(--dw-orange) !important; background:var(--dw-orange-soft); }

.rabatt-info { background:rgba(58,170,106,.08); border:1.5px solid rgba(58,170,106,.25); border-radius:8px; font-size:13px; font-weight:600; color:#2a8a52; }

/* ─── OP view ─────────────────────────────────────────────────── */
.op-stat-card { background:#fff; }
.op-stat-card .stat-val { font-size:22px; font-weight:800; letter-spacing:-.5px; }
.op-stat-card .stat-lbl { font-size:10px; font-weight:700; letter-spacing:.6px; text-transform:uppercase; color:#9aabaa; }
.op-stat-card .stat-sub { font-size:11px; color:#9aabaa; }
.op-stat-card.overdue .stat-val { color:#dc3545; }
.op-stat-card.open    .stat-val { color:var(--dw-orange); }

.table-op thead th { background:var(--dw-dark); color:#fff; font-size:11px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; border:none; white-space:nowrap; }
.table-op tbody td { background:#fff; }

/* ─── Success modal ───────────────────────────────────────────── */
.success-icon-wrap { width:72px; height:72px; background:rgba(58,170,106,.12); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 18px; font-size:36px; color:#3aaa6a; }
.order-number { font-size:22px; font-weight:800; color:var(--dw-orange); letter-spacing:1px; }

/* ─── Form labels ─────────────────────────────────────────────── */
.form-label { font-size:11px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:#8a9b99; }
.form-control, .form-select { font-family:'Montserrat',sans-serif; font-size:13.5px; background-color:#fff; }
.input-group-text { background-color:#fff; }
.form-control:focus, .form-select:focus { border-color:var(--dw-orange); box-shadow:0 0 0 .2rem rgba(238,118,32,.20); }

.card { border:1.5px solid #e5e8e3; background:#fff; overflow:hidden; }
.card-header { background:#fff; font-weight:700; font-size:13px; border-bottom:1.5px solid #e5e8e3; }
.table-responsive { border-radius: inherit; }

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

/* ─── Flatpickr overrides ─────────────────────────────────────── */
.flatpickr-calendar { font-family:'Montserrat',sans-serif; border-radius:10px; box-shadow:0 6px 24px rgba(0,0,0,.12); border:1.5px solid #e5e8e3; }
.flatpickr-day.selected, .flatpickr-day.selected:hover { background:var(--dw-orange); border-color:var(--dw-orange); }
.flatpickr-day:hover { background:var(--dw-orange-soft); border-color:transparent; }
.flatpickr-day.today { border-color:var(--dw-orange); }
.flatpickr-day.today:hover { background:var(--dw-orange-soft); }
.flatpickr-months .flatpickr-month { background:var(--dw-dark); border-radius:8px 8px 0 0; }
.flatpickr-months .flatpickr-prev-month, .flatpickr-months .flatpickr-next-month { color:#fff; fill:#fff; display:flex; align-items:center; justify-content:center; }
.flatpickr-months .flatpickr-prev-month:hover svg, .flatpickr-months .flatpickr-next-month:hover svg { fill:var(--dw-orange); }
.flatpickr-current-month { font-size:13px; font-weight:700; color:#fff; }
.flatpickr-current-month { display:flex; align-items:center; justify-content:center; gap:10px; padding:0; }
.flatpickr-current-month .flatpickr-monthDropdown-months {
  color:#fff; background:transparent; font-family:'Montserrat',sans-serif; font-weight:700;
  border:none; outline:none; cursor:pointer; padding:0; margin:0; appearance:none; -webkit-appearance:none;
}
.flatpickr-current-month input.cur-year { color:#fff; font-weight:700; font-family:'Montserrat',sans-serif; padding:0; margin:0; }
.numInputWrapper { display:flex; align-items:center; position:relative; }
.numInputWrapper span {
  border:none; position:static; display:flex; align-items:center; justify-content:center;
  width:14px; height:14px; opacity:1; padding:0;
}
.numInputWrapper span::after {
  border-color:#fff transparent !important;
}
.numInputWrapper span.arrowUp  { top:auto; right:auto; }
.numInputWrapper span.arrowDown { top:auto; right:auto; }
.flatpickr-weekday { font-family:'Montserrat',sans-serif; font-size:11px; font-weight:700; color:#9aabaa; }
.flatpickr-day { font-family:'Montserrat',sans-serif; font-size:12.5px; border-radius:6px; }
