:root{
  --bg:#F4F1EA;
  --panel:#fffdf9;
  --panel2:#efe7dc;
  --stroke:#ddd1c3;
  --text:#1b1917;
  --muted:#6e675f;
  --danger:#a45a4d;
  --danger-soft:#f4e3df;
  --ok:#6f8d68;
  --ok-soft:#e8f1e9;
  --accent:#C46A3A;
  --brand:#3F4A3C;
  --brand-soft:#566354;
  --radius:18px;
  --radius2:12px;
  --shadow:0 10px 28px rgba(24,20,17,.08);
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
}
a{color:inherit}
header{
  position:sticky;
  top:0;
  z-index:20;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  background:rgba(244,241,234,.94);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--stroke);
}
.brand{display:flex; align-items:center; gap:10px; min-width:0}
.brand img{height:34px; width:auto; display:block}
.brand .title{font-weight:800; letter-spacing:.2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.adminIconBtn{
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  width:56px;
  height:56px;
  padding:0;
  border:1px solid var(--stroke);
  border-radius:16px;
  background:var(--accent);
  cursor:pointer;
  box-shadow:0 1px 0 rgba(255,255,255,.16) inset;
}
.adminIconBtn:active{transform:translateY(1px)}
.adminIconBtn img{
  width:46px;
  height:auto;
  display:block;
}
@media (max-width: 720px){
  header{
    gap:10px;
  }
}
header .spacer{flex:1}
.btn{
  border:1px solid var(--stroke);
  background:#ffffff;
  color:var(--text);
  padding:12px 14px;
  border-radius:14px;
  cursor:pointer;
  font-weight:700;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset;
}
.btn:active{transform:translateY(1px)}
.btn.primary{
  background:var(--accent);
  border-color:var(--accent);
  color:#fffdf9;
}

#btnHome{
  min-height:56px;
  min-width:140px;
  padding:0 26px;
  border-radius:16px;
  font-size:18px;
}
.btn.danger{
  border-color:#d7b1ab;
  background:var(--danger-soft);
  color:#6b261d;
}
.btn.icon{
  min-width:44px;
  min-height:44px;
  padding:10px 12px;
  font-weight:900;
}
.badge{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  padding:0 20px;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:#ffffff;
  font-size:16px;
  font-weight:900;
  letter-spacing:.2px;
  white-space:nowrap;
}
main{padding:14px; max-width:1100px; margin:0 auto}
.licenseBanner{
  margin:10px auto 0;
  max-width:1100px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--stroke);
  font-weight:800;
  box-shadow:var(--shadow);
}
.licenseBanner.hidden{display:none !important}
.licenseBanner.isGrace{
  background:#fff5de;
  border-color:#e7cf95;
  color:#6b4d12;
}
.licenseBanner.isBlocked{
  background:var(--danger-soft);
  border-color:#d7b1ab;
  color:#6b261d;
}
.licenseBlockedHint{
  margin-top:8px;
  font-size:12px;
  color:#6b261d;
  font-weight:800;
}
.card{
  background:var(--panel);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.row{display:flex; gap:14px; align-items:stretch}
.col{flex:1; min-width:0}
.hidden{display:none !important}

.h1{font-size:18px; font-weight:900; margin:0 0 10px 0}
.h2{font-size:14px; font-weight:700; margin:0 0 10px 0; color:var(--muted)}

#menuWrap{display:grid; grid-template-columns: 1.35fr .65fr; gap:14px}
@media (max-width: 900px){ #menuWrap{grid-template-columns:1fr} }

.tabs{display:flex; flex-wrap:wrap; gap:8px; padding:12px}
.tab{
  padding:11px 14px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background:#ffffff;
  cursor:pointer;
  font-weight:800;
  color:var(--text);
}
.tab.active{
  background:var(--panel2);
  border-color:#cfc5b8;
}

.grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap:12px;
  padding:12px;
}

.item{
  border:1px solid var(--stroke);
  background:#ffffff;
  border-radius:16px;
  padding:16px;
  cursor:pointer;
  min-height:96px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  color:var(--text);
  box-shadow:var(--shadow);
}
.item:active{transform:translateY(1px)}
.item.isBlocked, .quickBtn.isBlocked{
  opacity:.58;
  filter:grayscale(.15);
  border-color:#d7b1ab;
  background:#f4e3df;
  cursor:not-allowed;
}
.item .name{
  font-weight:900;
  font-size:18px;
  line-height:1.2;
  margin:0;
  text-align:center;
  width:100%;
}
.item .meta{
  color:var(--muted);
  font-size:13px;
  margin-top:6px;
}
.itemHint{
  margin-top:8px;
  font-size:12px;
  color:var(--muted);
}

.cart{padding:12px}
.cartRow, .cartLine{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px 0;
  border-bottom:1px solid rgba(27,25,23,.08);
}
.cartRow:last-child, .cartLine:last-child{border-bottom:none}
.cartRow.isBlocked .cartSwipeContent{opacity:.72}
.cartLeft{flex:1; min-width:0}
.cartName{
  font-weight:900;
  font-size:16px;
}
.cartNote{
  color:var(--muted);
  font-size:13px;
  margin-top:4px;
  white-space:pre-wrap;
}
.cartRight{
  display:flex;
  gap:8px;
  align-items:center;
}
.qty{
  font-family:var(--mono);
  min-width:34px;
  text-align:center;
  padding:8px 8px;
  border-radius:10px;
  border:1px solid var(--stroke);
  background:#ffffff;
}
.footerBtns{
  display:flex;
  gap:10px;
  padding:12px;
  border-top:1px solid rgba(27,25,23,.08);
}
.footerBtns .btn{flex:1}

.modalBack{
  position:fixed; inset:0; z-index:50;
  background:rgba(24,20,17,.24);
  display:flex; align-items:center; justify-content:center;
  padding:14px;
}
.modal{
  width:min(620px, 100%);
  max-height: calc(100vh - 60px);
  background:var(--panel);
  border:1px solid var(--stroke);
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.modal header{
  position:unset;
  background:var(--panel);
  border-bottom:1px solid rgba(27,25,23,.08);
}
.modal .body{
  padding:14px;
  max-height: calc(100vh - 140px);
  overflow:auto;
  -webkit-overflow-scrolling: touch;
}
.field{display:grid; gap:6px; margin-bottom:12px}
.field label{font-size:12px; color:var(--muted); font-weight:800}
.field input,.field select,.field textarea,
.input, .select, .textarea{
  width:100%;
  box-sizing:border-box;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background:#ffffff;
  color:var(--text);
  font-family:var(--sans);
  outline:none;
}
.field textarea{min-height:110px; font-family:var(--sans)}
.field select option, .select option, select, option{
  background:#fffdf9;
  color:var(--text);
}
.select{appearance:none}
.split{display:grid; grid-template-columns:1fr 1fr; gap:12px}
@media (max-width: 700px){ .split{grid-template-columns:1fr} }
.hr{height:1px; background:rgba(27,25,23,.08); margin:12px 0}
.small{font-size:12px; color:var(--muted)}
.toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  background:var(--brand);
  color:#fffdf9;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  z-index:60;
  font-weight:700;
}

#itemsGrid{max-height:none; overflow:visible;}
#cartLines{max-height:none; overflow:visible;}
.miniTag{display:inline-block;padding:2px 6px;border-radius:999px;font-size:12px;margin-left:6px;background:var(--panel2);}

/* Home: table list */
#tableList{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:12px;
}
.tableBtn{
  width:100%;
  min-height:74px;
  font-size:22px;
  font-weight:900;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:#ffffff;
  color:var(--text);
  cursor:pointer;
  text-align:left;
  padding:16px 18px;
  box-shadow:var(--shadow);
}
.tableBtn:active{transform:translateY(1px)}
.tableBtn.free{
  background:linear-gradient(180deg, #ffffff 0%, #fbf9f5 100%);
  border-left:8px solid var(--ok);
}
.tableBtn.occupied{
  background:linear-gradient(180deg, #ffffff 0%, #fcf7f5 100%);
  border-left:8px solid var(--danger);
}

.longpressable{
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
}

@media (max-width: 640px){
  header{padding:12px}
  .btn{padding:12px 14px; font-size:17px}
  .adminIconBtn{
    width:52px;
    height:52px;
    border-radius:15px;
  }
  .adminIconBtn img{
    width:40px;
    height:auto;
  }
  .badge{
    min-height:52px;
    padding:0 16px;
    font-size:15px;
  }
  #btnHome{
    min-height:52px;
    min-width:116px;
    padding:0 20px;
    font-size:17px;
  }
  .tab{padding:12px 14px; font-size:16px}
  .grid{grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap:12px}
  .item{padding:16px; min-height:88px}
  .item .name{font-size:19px}
}


.modal textarea{
  width:100%;
  box-sizing:border-box;
}


.adminTopTabs{
  display:flex;
  align-items:center;
  gap:10px;
}

.adminTopTabs .tab:first-child{
  margin-right:auto;
}

.adminTopTabs .tab:last-child{
  margin-left:auto;
}

.adminItemActions{
  margin-left:auto;
  justify-content:flex-end;
  align-self:stretch;
}

.subtleDelete{
  margin-left:auto;
  background:var(--danger-soft);
  color:#6b261d;
  border:1px solid #d7b1ab;
  padding:6px 10px;
  font-size:13px;
  font-weight:700;
  border-radius:10px;
  box-shadow:none;
}

.subtleDelete:hover{
  background:#efd3cd;
}

.adminStationPicker{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.adminStationBtn{
  border:1px solid var(--stroke);
  background:#ffffff;
  color:var(--text);
  padding:11px 14px;
  border-radius:14px;
  cursor:pointer;
  font-weight:700;
  font-size:16px;
  line-height:1.2;
}

.adminStationBtn.active{
  background:var(--panel2);
  border-color:#cfc5b8;
}

.footerBtns{
  position:sticky;
  bottom:0;
  background:linear-gradient(180deg, rgba(255,253,249,.82) 0%, rgba(255,253,249,.98) 35%);
  backdrop-filter: blur(8px);
}

@media (max-width: 720px){
  .adminTopTabs{
    gap:8px;
  }

  .adminStationBtn{
    flex:1 1 calc(50% - 8px);
    text-align:center;
  }

  .adminItemActions{
    width:100%;
  }

  .subtleDelete{
    width:auto;
  }
}


#screenAdmin{
  min-height:calc(100vh - 92px);
}
.adminScreenShell{
  display:grid;
  gap:12px;
}
.adminScreenHeader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:4px;
}
.adminScreenTitle{
  font-size:28px;
  font-weight:900;
  letter-spacing:.2px;
}

.adminScreenTitle.loggingHeaderBtnHost{
  display:flex;
  align-items:center;
  min-height:52px;
  font-size:0;
  line-height:1;
}

.loggingHeaderBtn{
  width:52px;
  min-width:52px;
  height:52px;
  min-height:52px;
  padding:0;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  font-weight:900;
}

@media (max-width: 720px){
  .adminScreenTitle.loggingHeaderBtnHost{
    min-height:48px;
  }

  .loggingHeaderBtn{
    width:48px;
    min-width:48px;
    height:48px;
    min-height:48px;
    border-radius:14px;
    font-size:24px;
  }
}
.adminScreenBody{
  display:grid;
  gap:14px;
}
.adminScreenBody .adminV28Root{
  gap:12px;
}
.adminScreenBody .adminTopTabs,
.adminScreenBody .adminCategoryTabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:8px;
}
.adminScreenBody .adminSection{
  gap:10px;
}
.adminScreenBody .adminCards{
  gap:10px;
}
.adminScreenBody .adminItemCard,
.adminScreenBody .adminEmpty{
  padding:12px;
}
.adminScreenBody .adminItemRow{
  align-items:flex-start;
}
.adminScreenBody .adminItemFields{
  gap:6px;
}
.adminScreenBody .adminInlineField{
  max-width:none;
}
.adminScreenBody .adminNameInput{
  font-size:17px;
}
.adminScreenBody .adminStationPicker{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.adminScreenBody .adminStationBtn{
  flex:0 0 auto;
  padding:7px 10px;
  border-radius:10px;
  font-size:14px;
  font-weight:700;
  line-height:1;
}
.adminScreenBody .adminItemActions{
  margin-left:auto;
  justify-content:flex-end;
  align-items:flex-start;
  align-self:flex-start;
}
.adminScreenBody .adminStationChip{
  min-height:32px;
  padding:0 10px;
  font-size:13px;
}
.adminScreenBody .subtleDelete{
  margin-left:auto;
  padding:5px 9px;
  font-size:12px;
  border-radius:9px;
  background:var(--danger-soft);
  color:#6b261d;
  border:1px solid #d7b1ab;
}
.adminScreenBody .footerBtns{
  position:sticky;
  bottom:0;
  z-index:5;
  padding:10px 0 0;
  border-top:none;
  background:linear-gradient(180deg, rgba(246,243,238,0) 0%, rgba(246,243,238,.96) 26%, rgba(246,243,238,1) 100%);
  backdrop-filter:blur(8px);
}
.adminScreenBody .footerBtns .btn{
  min-height:52px;
}
@media (max-width: 720px){
  main{padding:10px;}
  #screenAdmin{min-height:calc(100vh - 84px);}
  .adminScreenTitle{font-size:24px;}
  .adminScreenBody .adminTopTabs{
    justify-content:space-between;
    align-items:center;
  }
  .adminScreenBody .adminTopTabs .tab:first-child{margin-right:auto;}
  .adminScreenBody .adminTopTabs .tab:last-child{margin-left:auto;}
  .adminScreenBody .adminCategoryTabs .tab{
    padding:10px 12px;
    font-size:15px;
  }
  .adminScreenBody .adminItemRow{
    gap:10px;
  }
  .adminScreenBody .adminItemActions{
    width:100%;
    margin-left:0;
    justify-content:space-between;
    align-items:center;
  }
  .adminScreenBody .adminStationPicker{
    gap:6px;
  }
  .adminScreenBody .adminStationBtn{
    flex:1 1 auto;
    min-width:0;
    text-align:center;
  }
  .adminScreenBody .subtleDelete{
    margin-left:auto;
  }
}


.weeklyImportTextarea{
  width:100%;
  min-height:220px;
  resize:vertical;
}

.weeklyImportPreview{
  padding:12px;
  margin-top:12px;
}

.weeklyImportPreviewList{
  display:grid;
  gap:8px;
}

.weeklyImportPreviewRow{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:8px 0;
  border-bottom:1px solid rgba(27,25,23,.08);
}

.weeklyImportPreviewRow:last-child{
  border-bottom:none;
}

.weeklyImportPreviewName{
  font-weight:700;
}

.weeklyImportPreviewStation{
  color:var(--muted);
  font-size:13px;
  white-space:nowrap;
}

/* v2 mobile overflow fix */
html, body {
  overflow-x: hidden;
}
main,
#screenAdmin,
.adminScreenShell,
.adminScreenBody,
.adminScreenBody .adminV28Root,
.adminScreenBody .adminPanelWrap,
.adminScreenBody .adminSection,
.adminScreenBody .adminCards,
.adminScreenBody .adminItemCard {
  max-width: 100%;
  overflow-x: clip;
}

@media (max-width: 720px){
  .adminScreenBody .footerBtns{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
    gap:10px !important;
    align-items:stretch;
  }

  .adminScreenBody .footerBtns .btn{
    flex:0 0 auto !important;
    width:100% !important;
    min-width:0 !important;
    white-space:normal !important;
    word-break:break-word;
  }

  .adminScreenBody .footerBtns .btn.danger{
    font-weight:600;
  }

  .adminScreenBody .adminTopTabs,
  .adminScreenBody .adminCategoryTabs{
    max-width:100%;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
}


.adminImportTopBar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
}

.adminImportTopBar .btn{
  flex:0 0 auto;
}

.adminImportTopBar .btn.primary{
  margin-left:auto;
}

.adminScreenBody .weeklyImportTextarea{
  width:100%;
  min-height:320px;
  resize:vertical;
  font-size:16px;
  line-height:1.35;
}

.adminScreenBody .weeklyImportPreview{
  padding:12px;
}

@media (max-width: 720px){
  .adminImportTopBar{
    display:grid;
    grid-template-columns:1fr;
  }

  .adminImportTopBar .btn,
  .adminImportTopBar .btn.primary{
    width:100%;
    margin-left:0;
  }

  .adminScreenBody .weeklyImportTextarea{
    min-height:260px;
  }
}

/* PWA / iOS */
html, body {
  min-height: 100%;
}
body {
  padding-top: env(safe-area-inset-top, 0);
  padding-right: env(safe-area-inset-right, 0);
  padding-bottom: env(safe-area-inset-bottom, 0);
  padding-left: env(safe-area-inset-left, 0);
}


/* iOS no-zoom + app-like touch polish */
input,
textarea,
select {
  font-size: 16px;
}

.modal textarea,
.field input,
.field select,
.field textarea,
.input,
.select,
.textarea {
  font-size: 16px;
}

html {
  -webkit-text-size-adjust: 100%;
  height: -webkit-fill-available;
}

body {
  min-height: 100vh;
  min-height: -webkit-fill-available;
  overscroll-behavior: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

button,
.btn,
.tab,
.item,
.tableBtn,
.adminStationBtn,
.subtleDelete {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

#itemsGrid,
#cartLines,
.modal .body,
.adminScreenBody .adminTopTabs,
.adminScreenBody .adminCategoryTabs {
  -webkit-overflow-scrolling: touch;
}


/* Disable accidental text selection in app UI */
*{
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}

/* Allow text selection inside inputs */
input,
textarea{
  -webkit-user-select:text;
  user-select:text;
}

/* Extra POS-style touch safety */
body{
  -webkit-user-drag:none;
}



@media (max-width: 900px){
  .item{
    min-height:88px;
    padding:14px;
  }

  .item .name{
    font-size:17px;
  }
}


/* Quick buttons centered */
#quickBar{
  display:flex !important;
  justify-content:center !important;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

#quickBar .btn{
  min-width:110px;
  text-align:center;
  font-weight:700;
  padding:10px 14px;
}

/* v31.1 quick articles */
#quickBar{
  display:flex;
  justify-content:center;
  align-items:stretch;
  gap:10px;
  flex-wrap:wrap;
  padding:0 12px 12px;
}

#quickBar .quickBtn{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  min-width:140px;
  min-height:72px;
  text-align:center;
  padding:12px 14px;
}

#quickBar .quickBtn.isPlaceholder,
#quickBar .quickBtn:disabled{
  opacity:.5;
  cursor:default;
}

.quickBtnLabel{
  font-weight:800;
  line-height:1.15;
}

.quickBtnMeta{
  font-size:12px;
  color:var(--muted);
  line-height:1.1;
}

@media (max-width: 720px){
  #quickBar{
    padding:0 12px 12px;
    gap:8px;
  }

  #quickBar .quickBtn{
    flex:1 1 calc(33.333% - 8px);
    min-width:0;
    min-height:68px;
    padding:10px 8px;
  }

  .quickBtnLabel{
    font-size:14px;
  }
}


/* v33.1 go-live layout polish: quick buttons / categories / articles */
#quickBar{
  margin-top:14px !important;
  padding:12px 12px 14px !important;
  border-bottom:2px solid var(--stroke);
}

#quickBar .quickBtn,
#quickBar .btn{
  background:#f3ede6;
  border-color:#e1d7cd;
  box-shadow:0 1px 0 rgba(255,255,255,.55) inset;
}

#menuWrap .tabs{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
  padding:14px 12px 14px;
  border-bottom:2px solid var(--stroke);
}

#menuWrap .tabs .tab{
  min-width:0;
  padding:10px 10px;
  font-size:14px;
  line-height:1.15;
  text-align:center;
}

#menuWrap .tabs .tab.active{
  background:var(--accent);
  color:#fffdf9;
  border-color:var(--accent);
  font-weight:800;
}

#menuWrap .grid{
  padding-top:14px;
  gap:12px;
}

#menuWrap .grid .item{
  min-height:104px;
  padding:18px 12px;
}

#menuWrap .grid .item .name{
  font-size:19px;
}

@media (max-width: 720px){
  #quickBar{
    margin-top:12px !important;
    padding:10px 12px 12px !important;
  }

  #quickBar .quickBtn{
    min-height:70px;
  }

  #menuWrap .tabs{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
    padding:12px 12px 12px;
  }

  #menuWrap .tabs .tab{
    padding:10px 6px;
    font-size:13px;
  }

  #menuWrap .grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
    padding:12px;
  }

  #menuWrap .grid .item{
    min-height:88px;
    padding:14px 10px;
    border-radius:14px;
  }

  #menuWrap .grid .item .name{
    font-size:17px;
  }

  #menuWrap .grid .item .itemHint,
  #menuWrap .grid .item .meta{
    font-size:11px;
    margin-top:6px;
  }
}


/* v33.2 Varianten: maximal 3 Optionen pro Zeile */
.variantOptions{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:8px;
}

.variantOptions .variantOptionBtn,
.variantOptions .btn{
  min-width:0;
}

@media (max-width: 720px){
  .variantOptions{
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
    gap:8px;
  }
}


/* vNext: add-to-cart feedback */
.item,
.quickBtn,
#cartSub,
#cartLines,
.cartRow{
  will-change: transform, box-shadow, background-color, border-color, filter;
}

.item,
.quickBtn{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  transition:transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background-color 120ms ease, filter 120ms ease;
}

.item::after,
.quickBtn::after{
  content:"";
  position:absolute;
  inset:-18%;
  background:linear-gradient(115deg, rgba(255,255,255,0) 18%, rgba(255,255,255,.16) 38%, rgba(255,255,255,.58) 50%, rgba(255,255,255,.16) 62%, rgba(255,255,255,0) 82%);
  transform:translateX(-135%) skewX(-18deg);
  opacity:0;
  pointer-events:none;
  z-index:0;
}

.item > *,
.quickBtn > *{
  position:relative;
  z-index:2;
}

.item.is-added,
.quickBtn.is-added{
  animation:tbAddPulse 420ms cubic-bezier(.22,.9,.24,1);
}

.item.is-added::after,
.quickBtn.is-added::after{
  opacity:1;
  animation:tbAddSweep 420ms ease-out;
}

.item.is-added .name,
.quickBtn.is-added .name{
  animation:tbAddLabelPop 320ms ease-out;
}

#cartSub.cartBump,
#cartLines.cartBump{
  animation: tbCartBump 240ms ease-out;
}

.cartRow.cartRowAdded{
  animation: tbCartRowFlash 320ms ease-out;
}

@keyframes tbAddPulse{
  0%{
    transform:scale(1) translateY(0);
    filter:brightness(1);
    background:#ffffff;
    border-color:var(--stroke);
    box-shadow:var(--shadow);
  }
  14%{
    transform:scale(.89) translateY(2px);
    filter:brightness(.94) saturate(.98);
    background:#ead2c0;
    border-color:#b9653d;
    box-shadow:0 0 0 1px rgba(185,101,61,.16) inset;
  }
  36%{
    transform:scale(1.065) translateY(-3px);
    filter:brightness(1.04) saturate(1.08);
    background:#f3ddcf;
    border-color:#c46a3a;
    box-shadow:0 0 0 4px rgba(196,106,58,.22), 0 18px 36px rgba(196,106,58,.24);
  }
  54%{
    transform:scale(.975) translateY(1px);
    filter:brightness(1.01);
    background:#fbf1e8;
    border-color:#cf7b50;
    box-shadow:0 0 0 2px rgba(196,106,58,.12), 0 8px 18px rgba(196,106,58,.14);
  }
  72%{
    transform:scale(1.02) translateY(-1px);
    filter:brightness(1.015);
  }
  100%{
    transform:scale(1) translateY(0);
    filter:brightness(1);
    background:#ffffff;
    border-color:var(--stroke);
    box-shadow:var(--shadow);
  }
}

@keyframes tbAddSweep{
  0%{ transform:translateX(-145%) skewX(-18deg); opacity:0; }
  18%{ opacity:.35; }
  38%{ opacity:1; }
  100%{ transform:translateX(145%) skewX(-18deg); opacity:0; }
}

@keyframes tbAddLabelPop{
  0%{ transform:scale(1) translateY(0); letter-spacing:0; }
  32%{ transform:scale(1.11) translateY(-1px); letter-spacing:.01em; }
  58%{ transform:scale(.98) translateY(1px); }
  100%{ transform:scale(1) translateY(0); letter-spacing:0; }
}

@keyframes tbCartBump{
  0%{ transform:scale(1); }
  40%{ transform:scale(1.01); }
  100%{ transform:scale(1); }
}

@keyframes tbCartRowFlash{
  0%{ background:transparent; }
  35%{ background:#f7eee5; }
  100%{ background:transparent; }
}



.loggingMiniLeader{
  margin-top:8px;
  font-size:12px;
  color:var(--text);
  font-weight:700;
  line-height:1.3;
}

.loggingHeadBadge{
  align-self:flex-start;
  border:1px solid var(--stroke);
  background:#ffffff;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:800;
  color:var(--muted);
}

.loggingLoadingCard{
  padding:14px;
}

@media (max-width: 720px){
  .loggingHeadBadge{
    margin-top:6px;
    display:inline-flex;
  }
}


/* Logging layout */
.loggingRoot{
  display:grid;
  gap:14px;
}

.loggingHeroCard,
.loggingPeriodCard{
  padding:16px;
}

.loggingHeroTop{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
}

.loggingHeroTitle{
  font-size:24px;
  font-weight:900;
  line-height:1.1;
}

.loggingHeroStamp{
  font-size:13px;
  color:var(--muted);
  font-weight:700;
}

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

.loggingStatCard{
  background:#ffffff;
  border:1px solid var(--stroke);
  border-radius:16px;
  padding:14px;
  box-shadow:var(--shadow);
}

.loggingStatLabel{
  font-size:13px;
  font-weight:800;
  color:var(--muted);
  margin-bottom:6px;
}

.loggingStatValue{
  font-size:40px;
  line-height:1;
  font-weight:900;
  letter-spacing:-0.03em;
}

.loggingStatMeta{
  margin-top:6px;
  font-size:13px;
  color:var(--muted);
  font-weight:700;
}

.loggingStatLeader{
  margin-top:10px;
  font-size:13px;
  font-weight:800;
  color:var(--text);
  line-height:1.3;
}

.loggingPeriodHead{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:14px;
}

.loggingPeriodTitle{
  font-size:22px;
  font-weight:900;
  line-height:1.1;
}

.loggingPeriodMeta{
  margin-top:4px;
  font-size:13px;
  color:var(--muted);
  font-weight:700;
}

.loggingHeadBadge{
  align-self:flex-start;
  border:1px solid var(--stroke);
  background:#ffffff;
  border-radius:999px;
  padding:7px 11px;
  font-size:12px;
  font-weight:800;
  color:var(--muted);
  white-space:nowrap;
}

.loggingLeaderBox{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px;
  border:1px solid var(--stroke);
  border-radius:16px;
  background:linear-gradient(180deg, #ffffff 0%, #fbf9f5 100%);
  margin-bottom:14px;
}

.loggingLeaderLabel{
  font-size:12px;
  font-weight:800;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.04em;
}

.loggingLeaderName{
  margin-top:3px;
  font-size:20px;
  font-weight:900;
  line-height:1.15;
}

.loggingLeaderDetail{
  margin-top:4px;
  font-size:13px;
  font-weight:700;
  color:var(--muted);
}

.loggingLeaderQty,
.loggingQty{
  border:1px solid var(--stroke);
  background:#ffffff;
  border-radius:999px;
  padding:8px 12px;
  min-width:58px;
  text-align:center;
  font-weight:900;
  font-size:15px;
}

.loggingList{
  display:grid;
  gap:10px;
}

.loggingRow{
  padding:12px 0 0;
  border-top:1px solid rgba(27,25,23,.08);
}

.loggingRow:first-child{
  border-top:none;
  padding-top:0;
}

.loggingRowTop{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}

.loggingRowLeft{
  display:flex;
  align-items:flex-start;
  gap:12px;
  min-width:0;
  flex:1;
}

.loggingRank{
  flex:0 0 34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--panel2);
  font-weight:900;
  font-size:14px;
}

.loggingTextWrap{
  min-width:0;
  flex:1;
}

.loggingName{
  font-size:17px;
  font-weight:900;
  line-height:1.2;
  word-break:break-word;
}

.loggingDetail{
  margin-top:4px;
  font-size:13px;
  color:var(--muted);
  font-weight:700;
}

.loggingBar{
  margin-top:10px;
  height:8px;
  border-radius:999px;
  background:#eee5d8;
  overflow:hidden;
}

.loggingBarFill{
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, var(--accent) 0%, #d48a59 100%);
}

.loggingEmpty{
  font-size:14px;
  color:var(--muted);
  font-weight:700;
}

.loggingLoadingCard{
  padding:14px;
}

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

@media (max-width: 640px){
  .loggingHeroCard,
  .loggingPeriodCard{
    padding:14px;
  }

  .loggingHeroTitle{
    font-size:22px;
  }

  .loggingSummaryGrid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .loggingStatValue{
    font-size:34px;
  }

  .loggingPeriodHead,
  .loggingLeaderBox,
  .loggingRowTop{
    flex-direction:column;
    align-items:stretch;
  }

  .loggingHeadBadge,
  .loggingLeaderQty,
  .loggingQty{
    align-self:flex-start;
  }

  .loggingRowLeft{
    gap:10px;
  }

  .loggingRank{
    flex-basis:30px;
    height:30px;
    font-size:13px;
  }

  .loggingName{
    font-size:16px;
  }
}

/* --- TableBon Swipe UX --- */
.cartRow{
  position:relative;
  display:block;
  overflow:hidden;
  touch-action:pan-y;
}

.cartSwipeContent{
  position:relative;
  z-index:2;
  display:flex;
  gap:10px;
  align-items:flex-start;
  width:100%;
  padding:12px 0;
  background:var(--panel);
  transition:transform .18s ease;
  will-change:transform;
}

.swipeDeleteBg,
.swipePlusBg{
  position:absolute;
  top:0;
  bottom:0;
  width:96px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:14px;
  letter-spacing:.2px;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
  z-index:1;
}

.swipeDeleteBg{
  right:0;
  background:#c62828;
  color:#fff;
  border-radius:12px;
}

.swipePlusBg{
  left:0;
  background:#2e7d32;
  color:#fff;
  border-radius:12px;
}



/* Splash Screen */

#splash{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#F4F1EA;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity .35s ease;
}

#splash img{
  width:80vw;
  max-width:900px;
  height:auto;
}

#splash.hide{
  opacity:0;
  pointer-events:none;
}


/* --- TableBon Header FINAL --- */

.tbHeader{
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: rgba(244,241,234,.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--stroke);
}

/* LOGO = ADMIN BUTTON */
.tbHeader .adminIconBtn{
  height: 56px;
  padding: 0 12px;

  border: none;
  border-radius: 16px;
  background: transparent;

  display: flex;
  align-items: center;
  justify-content: center;

  cursor: pointer;
}

.tbHeader .adminIconBtn img{
  height: 38px;
  width: auto;
  display: block;
}

/* CENTER BADGE */
.tbHeader .badge{
  min-width: 0;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;

  padding: 0 22px;
  min-height: 56px;
  font-size: 18px;

  border-radius: 18px;
  background: #ffffff;
  border: 1px solid var(--stroke);
}

/* HOME */
.tbHeader #btnHome{
  min-width: 120px;
  height: 56px;
  padding: 0 22px;
  border-radius: 18px;
  justify-self: end;
}

/* MOBILE */
@media (max-width: 720px){
  .tbHeader{
    gap: 10px;
    padding: 10px 12px;
  }

  .tbHeader .adminIconBtn{
    height: 48px;
    padding: 0 10px;
    border-radius: 14px;
  }

  .tbHeader .adminIconBtn img{
    height: 32px;
  }

  .tbHeader .badge{
    min-height: 48px;
    padding: 0 16px;
    font-size: 16px;
    border-radius: 16px;
  }

  .tbHeader #btnHome{
    min-width: 88px;
    height: 48px;
    padding: 0 16px;
    font-size: 16px;
    border-radius: 16px;
  }
}

/* defensive: old spacer from previous header versions */
header .spacer{
  display:none !important;
}



.adminSystemCard{
  width:100%;
  max-width:420px;
}

@media (min-width: 900px){
  .adminSystemCard{
    max-width:860px;
  }
}


/* --- Logging UI fixes --- */
.loggingCategoryCard{
  opacity:1 !important;
  filter:none !important;
}


/* === operativ clean logging/system === */
.adminSystemSection{
  display:flex;
  justify-content:flex-start;
}

.adminSystemCard{
  width:100%;
  max-width:520px;
  padding:18px;
}

.adminSystemEyebrow{
  display:none;
}

.adminSystemTitle{
  font-size:26px;
  font-weight:900;
  line-height:1.05;
  margin:0 0 2px 0;
}

.adminToolsBtns{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.adminToolBtn{
  min-height:54px;
  padding:0 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.adminToolLabel{
  font-size:16px;
  font-weight:900;
}

.adminToolIcon{
  font-size:16px;
  line-height:1;
}

.loggingCategoryGrid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.loggingCategoryCard{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border:1px solid var(--stroke);
  border-radius:14px;
  background:var(--panel2);
  color:var(--text);
  box-shadow:none;
  opacity:1 !important;
  filter:none !important;
}

.loggingCategoryName{
  font-size:15px;
  font-weight:800;
  line-height:1.15;
}

.loggingCategoryQty{
  margin-top:0;
  font-size:20px;
  font-weight:900;
  line-height:1;
}

.loggingCategoryMeta{
  display:none;
}

.loggingHeroTop{
  margin-bottom:10px;
}

.loggingSummaryGrid .loggingStatLeader{
  display:none;
}

.loggingPeriodHead{
  align-items:flex-end;
}

.loggingJournalList{
  display:grid;
  gap:10px;
}

.loggingJournalRow{
  width:100%;
  border:1px solid var(--stroke);
  background:#ffffff;
  border-radius:16px;
  padding:14px 16px;
  text-align:left;
  box-shadow:none;
}

.loggingJournalRow .loggingRowTop{
  align-items:flex-start;
}

.loggingJournalAction{
  border:1px solid var(--stroke);
  background:#ffffff;
  border-radius:999px;
  padding:8px 12px;
  min-width:86px;
  text-align:center;
  font-weight:900;
  flex:0 0 auto;
}

.loggingJournalTimeline{
  margin-top:6px;
  font-size:13px;
  color:var(--muted);
  font-weight:700;
}

@media (max-width: 720px){
  .adminSystemCard{
    max-width:none;
    padding:16px;
  }

  .adminToolsBtns{
    display:grid;
    grid-template-columns:1fr 1fr;
  }

  .adminToolBtn{
    width:100%;
    justify-content:center;
    min-width:0;
    padding:0 14px;
  }

  .loggingCategoryGrid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }

  .loggingCategoryCard{
    justify-content:space-between;
    min-width:0;
  }

  .loggingJournalRow .loggingRowTop{
    flex-direction:column;
    gap:10px;
  }

  .loggingJournalAction{
    align-self:flex-start;
  }
}


/* --- journal chips / service emphasis --- */
.loggingChips{
  display:flex;
  gap:6px;
  margin-top:6px;
  flex-wrap:wrap;
}

.loggingChip{
  font-size:12px;
  font-weight:700;
  padding:4px 8px;
  border-radius:999px;
  background:var(--panel2);
  color:var(--text);
  line-height:1.1;
}

.loggingChip.chipTime{
  background:#e8efe9;
  color:#2d4a32;
}

.loggingJournalRow.is-mid{
  background:linear-gradient(180deg, #fffdf9 0%, #f8f4ee 100%);
}

.loggingJournalRow.is-long{
  background:linear-gradient(180deg, #fffdf9 0%, #f4ebe7 100%);
}


/* --- journal detail polish --- */
.loggingJournalFacts{
  display:grid;
  gap:12px;
}

.loggingFactGroup{
  padding:12px 14px;
  background:#ffffff;
  border:1px solid var(--stroke);
  border-radius:14px;
}

.loggingFactGroupTitle{
  font-size:12px;
  font-weight:800;
  color:var(--muted);
  margin-bottom:8px;
  text-transform:uppercase;
  letter-spacing:.4px;
}

.loggingFactRow{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:5px 0;
}

.loggingFactKey{
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}

.loggingFactValue{
  font-weight:800;
  text-align:right;
}

.loggingBonTitle{
  font-size:15px;
  font-weight:900;
}

.loggingJournalMiniRow{
  padding:10px 0;
  border-bottom:1px solid rgba(27,25,23,.08);
}

.loggingJournalMiniRow:last-child{
  border-bottom:none;
}

.loggingJournalOrderLines{
  margin-top:6px;
  padding-left:8px;
  display:grid;
  gap:4px;
}

.loggingJournalOrderLine{
  padding:0;
  background:transparent;
  border-radius:0;
}

.loggingJournalOrderLine .loggingDetail{
  font-size:13px;
  color:var(--muted);
}

.loggingQty{
  font-weight:900;
  background:var(--panel2);
  padding:6px 10px;
  border-radius:10px;
  font-size:13px;
  min-width:40px;
  text-align:center;
  align-self:flex-start;
}

@media (max-width: 720px){
  .loggingFactRow{
    flex-direction:column;
    gap:2px;
  }

  .loggingFactValue{
    text-align:left;
  }
}


/* --- journal detail modal refinement --- */
.loggingJournalModal{
  display:grid;
  gap:14px;
}

.loggingJournalSectionTitle{
  font-size:18px;
  font-weight:900;
  line-height:1.1;
  margin:0 0 12px 0;
}

.loggingJournalModalCard{
  padding:14px 16px;
}

.loggingJournalModalCard .loggingJournalMiniList{
  display:grid;
  gap:0;
}

.loggingJournalModalCard .loggingJournalMiniRow{
  display:flex !important;
  flex-direction:row !important;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:12px 0;
  border-bottom:1px solid rgba(27,25,23,.08);
}

.loggingJournalModalCard .loggingJournalMiniRow:last-child{
  border-bottom:none;
}

.loggingJournalMiniLeft{
  flex:1;
  min-width:0;
}

.loggingJournalModalCard .loggingQty{
  flex:0 0 auto;
  min-width:46px;
  align-self:flex-start;
  margin-left:8px;
  background:var(--panel2);
}

.loggingJournalOrderLines{
  margin-top:8px;
  padding-left:10px;
}

.loggingJournalOrderLine{
  padding:0;
  background:transparent;
  border-radius:0;
}

.loggingJournalOrderLine .loggingDetail{
  font-size:13px;
  line-height:1.35;
  color:var(--muted);
}

.loggingFactGroup:first-child{
  margin-top:0;
}

@media (max-width: 720px){
  .loggingJournalModalCard{
    padding:12px 14px;
  }

  .loggingJournalModalCard .loggingJournalMiniRow{
    gap:10px;
  }

  .loggingJournalModalCard .loggingQty{
    min-width:42px;
    padding:6px 9px;
  }
}



/* === Table button layout fix === */
.tableBtn{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.tableBtnLabel{
  flex:1;
  min-width:0;
}

.tableMeta{
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:auto;
}

.tableCountBadge{
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:32px;
  height:32px;
  border-radius:999px;
  background:#1b1917;
  color:#fff;
  font-size:14px;
  font-weight:900;
}

.tableServiceTimer{
  font-size:16px;
  opacity:.9;
}


/* Table overview: keep action button outside the main table button to avoid nested-button tap issues */
.tableBtnWrap{
  display:flex;
  align-items:stretch;
  gap:10px;
  width:100%;
}
.tableBtnWrap .tableBtn{
  flex:1 1 auto;
}
.tableBtnWrap .mergeQuickBtn{
  flex:0 0 52px;
  width:52px;
  min-width:52px;
  min-height:74px;
  border-radius:16px;
  border:1px solid var(--stroke);
  background:#ffffff;
  color:var(--text);
  font-size:22px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:var(--shadow);
}
.tableBtnWrap .mergeQuickBtn:active{
  transform:translateY(1px);
}


.tableBtnWrap .tableBtn.hasMergeQuick .tableMeta{
  margin-right:0;
}
.tableBtnWrap .mergeQuickBtn{
  position:static;
  top:auto;
  right:auto;
  transform:none;
  backdrop-filter:none;
  z-index:auto;
  transition:transform .08s ease, box-shadow .08s ease, background .08s ease;
}
.tableBtnWrap .mergeQuickBtn:active{
  transform:translateY(1px);
}


.loggingDayNav{
  display:flex;
  align-items:center;
  gap:8px;
}

.loggingDayNav .btn{
  min-width:44px;
  padding:0 12px;
}

.adminTableManagerRow{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}

.adminTableManagerFields{
  display:grid;
  grid-template-columns:140px minmax(0,1fr);
  gap:12px;
}

@media (max-width: 720px){
  .loggingDayNav{
    width:100%;
    justify-content:space-between;
  }

  .adminTableManagerRow{
    grid-template-columns:1fr;
  }

  .adminTableManagerFields{
    grid-template-columns:1fr 1fr;
  }
}


.printRulesPanel{padding:18px;}
.printRulesIntro{margin-bottom:18px;line-height:1.45;max-width:860px;}
.printRulesSectionHeading{
  margin:22px 0 12px 0;
  padding-top:14px;
  border-top:1px dashed rgba(27,25,23,.12);
  font-size:15px;
  letter-spacing:.02em;
}
.printRulesCardTitle{
  font-size:15px;
  font-weight:900;
  color:var(--muted);
  margin:0 0 14px 0;
}
.printRulesStationCard,
.printRulesRuleCard{
  padding:16px;
  margin-bottom:12px;
  background:linear-gradient(180deg,#fffdf9 0%,#fcfaf6 100%);
}
.printRulesStationGrid,
.printRulesConfigGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.printRulesConfigGrid{align-items:start;}
.printRulesField{margin-bottom:0;}
.printRulesFieldWide{grid-column:1 / -1;}
.printRulesOptionGrid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:14px 0 4px 0;
}
.printRulesCheckField{
  margin:14px 0 0 0;
  padding:12px 14px;
  border:1px solid rgba(27,25,23,.08);
  border-radius:16px;
  background:#fff;
}
.printRulesCheckRow{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.printRulesCheckRow input[type="checkbox"]{
  margin:2px 0 0 0;
  width:20px;
  height:20px;
  accent-color:var(--accent);
  flex:0 0 auto;
}
.printRulesCheckCopy{display:grid;gap:2px;min-width:0;}
.printRulesCheckLabel{font-weight:800;line-height:1.25;}
.printRulesCheckMeta{font-size:13px;line-height:1.35;color:var(--muted);}
.printRulesInfo{margin:0 0 12px 0;line-height:1.4;}
.printRulesInlineActions{
  display:flex;
  align-items:center;
  gap:10px;
  margin:6px 0 12px 0;
}
.printRulesRuleMeta{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  margin-top:14px;
}
.printRulesRuleMeta .printRulesCheckField{
  margin:0;
  flex:1 1 auto;
}
.printRulesFooter{
  margin-top:18px;
  padding:14px 0 0 0;
}
@media (max-width: 900px){
  .printRulesOptionGrid{
    grid-template-columns:1fr;
  }
}
@media (max-width: 720px){
  .printRulesPanel{padding:14px;}
  .printRulesStationGrid,
  .printRulesConfigGrid{
    grid-template-columns:1fr;
  }
  .printRulesRuleMeta{
    flex-direction:column;
    align-items:stretch;
  }
  .printRulesInlineActions .btn,
  .printRulesRuleMeta .btn{
    width:100%;
  }
}


/* --- admin layout polish v20260328 --- */
.adminPanelIntro{
  padding:16px 18px;
  margin-bottom:2px;
}

.adminPanelTitle{
  font-size:18px;
  font-weight:900;
  line-height:1.15;
}

.adminPanelText,
.adminSystemText{
  margin-top:4px;
  font-size:14px;
  line-height:1.35;
  color:var(--muted);
  font-weight:600;
}

.adminSection{
  display:grid;
  gap:12px;
}

.adminCards{
  display:grid;
  gap:14px;
}

.adminCategoryTabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:0;
}

.adminCategoryTabs .tab{
  min-width:0;
  padding:12px 16px;
  border-radius:16px;
  font-size:15px;
  line-height:1.15;
}

.adminItemCard{
  padding:16px;
}

.adminItemRow{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:start;
}

.adminItemFields{
  display:grid;
  gap:10px;
}

.adminItemFields > label,
.adminInlineField > label{
  font-size:12px;
  font-weight:800;
  color:var(--muted);
}

.adminInlineField{
  display:grid;
  gap:6px;
}

.adminNameInput{
  min-height:50px;
}

.adminItemActions{
  display:grid;
  gap:10px;
  align-content:start;
  justify-items:stretch;
  min-width:110px;
}

.adminItemActions > .btn,
.adminItemActions > .adminStationChip{
  width:100%;
  justify-content:center;
}

.adminStationChip{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  border-radius:14px;
  background:var(--panel2);
  border:1px solid var(--stroke);
  font-weight:800;
}

.adminScreenBody .footerBtns{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:10px;
}

.adminSystemSection{
  display:block;
}

.adminSystemCard{
  width:100%;
  max-width:none;
  padding:18px;
}

.adminToolsBtns{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:16px;
}

.adminToolBtn{
  min-height:86px;
  padding:16px 18px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:14px;
  text-align:left;
}

.adminToolIcon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:42px;
  min-width:42px;
  height:42px;
  border-radius:12px;
  background:var(--panel2);
  font-size:18px;
  line-height:1;
}

.adminToolCopy{
  display:grid;
  gap:2px;
  min-width:0;
}

.adminToolLabel{
  font-size:17px;
  font-weight:900;
  line-height:1.15;
}

.adminToolMeta{
  font-size:13px;
  color:var(--muted);
  font-weight:700;
  line-height:1.25;
}

@media (max-width: 720px){
  .adminPanelIntro{
    padding:14px 16px;
  }

  .adminCategoryTabs{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
  }

  .adminCategoryTabs .tab{
    width:100%;
    padding:11px 10px;
    font-size:14px;
    text-align:center;
  }

  .adminItemRow{
    grid-template-columns:1fr;
    gap:14px;
  }

  .adminItemActions{
    grid-template-columns:repeat(4, minmax(0, 1fr));
    min-width:0;
  }

  .adminItemActions > .subtleDelete{
    grid-column:span 2;
  }

  .adminItemActions > .adminStationChip,
  .adminItemActions > .btn{
    min-width:0;
  }

  .adminToolsBtns{
    grid-template-columns:1fr;
    gap:10px;
  }

  .adminToolBtn{
    min-height:74px;
    padding:14px 16px;
  }

  .adminToolLabel{
    font-size:16px;
  }

  .adminToolMeta{
    font-size:12px;
  }

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

  .adminScreenBody .footerBtns .btn.primary:last-child{
    grid-column:1 / -1;
  }
}


/* Döner-Profil: kompakter Counter auf Tablets */
@media (min-width: 721px) and (max-width: 1180px){
  body.profile-doener-counter-menu main{
    padding:8px 10px;
  }

  body.profile-doener-counter-menu .tbHeader{
    gap:6px;
    padding:6px 10px;
  }

  body.profile-doener-counter-menu .tbHeader .adminIconBtn{
    width:42px;
    height:42px;
    padding:0;
    border-radius:12px;
  }

  body.profile-doener-counter-menu .tbHeader .adminIconBtn img{
    width:32px;
  }

  body.profile-doener-counter-menu .tbHeader .badge{
    min-height:40px;
    padding:0 12px;
    font-size:14px;
    border-radius:12px;
  }

  body.profile-doener-counter-menu .tbHeader #btnHome{
    min-width:76px;
    min-height:40px;
    padding:0 12px;
    font-size:14px;
    border-radius:12px;
  }

  body.profile-doener-counter-menu #menuWrap{
    gap:10px;
  }

  body.profile-doener-counter-menu #menuWrap .card{
    border-radius:14px;
  }

  body.profile-doener-counter-menu #profileModeBar{
    gap:6px;
    margin:0 0 6px 0;
  }

  body.profile-doener-counter-menu #profileModeBar .profileModeBtn{
    min-height:38px;
    padding:6px 10px;
    border-radius:11px;
    font-size:13px;
  }

  body.profile-doener-counter-menu #superCategorySection{
    gap:8px;
    margin:0 0 8px 0;
  }

  body.profile-doener-counter-menu .superCategoryGrid{
    gap:8px;
  }

  body.profile-doener-counter-menu .superCatItem{
    min-height:74px;
    padding:8px 8px 10px;
    border-radius:12px;
    gap:4px;
  }

  body.profile-doener-counter-menu .superCatItem .name{
    font-size:15px;
    line-height:1.1;
  }

  body.profile-doener-counter-menu .superCatItem .itemHint,
  body.profile-doener-counter-menu .superCatBadge{
    font-size:10px;
  }

  body.profile-doener-counter-menu #menuWrap .tabs{
    gap:6px;
    padding:8px;
  }

  body.profile-doener-counter-menu #menuWrap .tabs .tab{
    padding:7px 8px;
    font-size:12px;
    border-radius:11px;
  }

  body.profile-doener-counter-menu #menuWrap .grid{
    gap:8px;
    padding:8px;
  }

  body.profile-doener-counter-menu #menuWrap .grid .item{
    min-height:76px;
    padding:10px 8px;
    border-radius:12px;
  }

  body.profile-doener-counter-menu #menuWrap .grid .item .name{
    font-size:16px;
  }

  body.profile-doener-counter-menu #menuWrap .cart{
    padding:10px;
  }

  body.profile-doener-counter-menu #menuWrap .footerBtns{
    gap:8px;
    padding:10px;
  }
}


/* ===== TableBon Design Refresh (integrated complete file) ===== */

/*
  TableBon design refresh override
  Load AFTER the existing TableBon styles.css
  Goal: calmer hierarchy, fresher surfaces, unchanged interaction model
*/

:root{
  --tb-surface-soft:#f8f4ee;
  --tb-surface-elevated:#fffdfa;
  --tb-stroke-strong:#d4c6b5;
  --tb-shadow-soft:0 12px 28px rgba(24,20,17,.06);
  --tb-shadow-mid:0 18px 42px rgba(24,20,17,.09);
  --tb-shadow-top:0 10px 24px rgba(24,20,17,.08);
}

body{
  background:
    radial-gradient(circle at top center, rgba(255,255,255,.42) 0%, rgba(255,255,255,0) 42%),
    linear-gradient(180deg, #f6f2eb 0%, var(--bg) 100%);
}

main{
  max-width:1200px;
  padding:18px 16px 22px;
}

.card,
.modal,
#menuWrap > .card,
#menuWrap > section,
#menuWrap > aside{
  box-shadow:var(--tb-shadow-soft);
}

/* Header: calmer and more intentional */
.tbHeader{
  gap:14px;
  padding:14px 18px;
  background:rgba(246,242,235,.84);
  border-bottom:1px solid rgba(212,198,181,.85);
  box-shadow:var(--tb-shadow-top);
}

.tbHeader .adminIconBtn{
  min-width:56px;
  height:56px;
  padding:0 12px;
  border:1px solid rgba(212,198,181,.9);
  border-radius:18px;
  background:linear-gradient(180deg, #ffffff 0%, #f7efe5 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.8) inset;
}

.tbHeader .adminIconBtn img{
  height:34px;
}

.tbHeader .badge{
  padding:0 24px;
  border-radius:18px;
  border-color:rgba(212,198,181,.92);
  background:linear-gradient(180deg, #ffffff 0%, #fcfaf6 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset;
  font-size:17px;
  letter-spacing:.01em;
}

.tbHeader #btnHome{
  min-width:124px;
  border-radius:18px;
  border-color:rgba(212,198,181,.92);
  background:linear-gradient(180deg, #ffffff 0%, #faf5ef 100%);
}

/* Stronger page staging */
#menuWrap{
  gap:18px;
  align-items:start;
}

#menuWrap > *{
  border-radius:22px;
  overflow:hidden;
}

/* Quick actions become a dedicated surface */
#quickBar{
  margin-top:10px !important;
  padding:14px !important;
  border:none !important;
  border-radius:20px 20px 0 0;
  background:linear-gradient(180deg, #f8f3ec 0%, #f4ede4 100%);
}

#quickBar .quickBtn,
#quickBar .btn{
  min-height:74px;
  border-radius:16px;
  background:linear-gradient(180deg, #ffffff 0%, #fbf7f2 100%);
  border:1px solid rgba(212,198,181,.9);
  box-shadow:0 1px 0 rgba(255,255,255,.75) inset;
}

.quickBtnLabel{
  font-size:15px;
}

.quickBtnMeta{
  margin-top:2px;
  font-size:11px;
  letter-spacing:.01em;
}

/* Categories get clearer segmentation */
#menuWrap .tabs{
  gap:10px;
  padding:0 14px 14px;
  border:none;
  background:linear-gradient(180deg, #f8f3ec 0%, #fbf8f4 100%);
}

#menuWrap .tabs .tab{
  min-height:52px;
  padding:12px 12px;
  border-radius:16px;
  border:1px solid rgba(212,198,181,.85);
  background:rgba(255,255,255,.88);
  box-shadow:none;
  transition:background-color .16s ease, border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}

#menuWrap .tabs .tab.active{
  background:linear-gradient(180deg, var(--accent) 0%, #d17b4e 100%);
  border-color:var(--accent);
  color:#fffdf9;
  box-shadow:0 8px 18px rgba(196,106,58,.18);
}

/* Article area becomes the visual focus */
#menuWrap .grid{
  padding:2px 14px 16px;
  gap:14px;
  align-content:start;
}

#menuWrap .grid .item{
  min-height:108px;
  padding:18px 14px;
  border-radius:18px;
  border:1px solid rgba(212,198,181,.82);
  background:linear-gradient(180deg, #ffffff 0%, var(--tb-surface-elevated) 100%);
  box-shadow:var(--tb-shadow-soft);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}

#menuWrap .grid .item .name{
  font-size:19px;
  line-height:1.16;
}

#menuWrap .grid .item .meta,
#menuWrap .grid .item .itemHint{
  color:#746d66;
}

@media (hover:hover){
  #menuWrap .grid .item:hover,
  #quickBar .quickBtn:hover,
  #quickBar .btn:hover,
  #menuWrap .tabs .tab:hover,
  #tableList .tableBtn:hover,
  .tableBtnWrap .mergeQuickBtn:hover{
    transform:translateY(-1px);
  }

  #menuWrap .grid .item:hover{
    border-color:rgba(196,106,58,.34);
    box-shadow:var(--tb-shadow-mid);
  }
}

/* Cart gets more separation from the menu */
.cart{
  padding:16px 16px 8px;
}

.cartRow,
.cartLine{
  padding:14px 0;
}

.cartName{
  font-size:17px;
  line-height:1.2;
}

.qty{
  min-width:38px;
  padding:9px 10px;
  border-radius:12px;
  border-color:rgba(212,198,181,.88);
  background:linear-gradient(180deg, #ffffff 0%, #f8f3ec 100%);
}

.footerBtns{
  padding:14px 16px 16px;
  border-top:1px solid rgba(212,198,181,.6);
  background:linear-gradient(180deg, rgba(255,253,249,.2) 0%, rgba(255,253,249,.96) 28%, rgba(255,253,249,1) 100%);
}

.footerBtns .btn{
  min-height:54px;
  border-radius:16px;
}

/* Home/table overview slightly more premium */
#tableList{
  gap:14px;
  padding:14px;
}

.tableBtn{
  min-height:78px;
  padding:18px 18px;
  border-radius:18px;
  border-color:rgba(212,198,181,.88);
  box-shadow:var(--tb-shadow-soft);
}

.tableBtn.free{
  background:linear-gradient(180deg, #ffffff 0%, #f9fbf8 100%);
}

.tableBtn.occupied{
  background:linear-gradient(180deg, #ffffff 0%, #fcf8f6 100%);
}

.tableCountBadge{
  box-shadow:0 6px 14px rgba(27,25,23,.12);
}

.tableBtnWrap .mergeQuickBtn{
  border-radius:18px;
  border-color:rgba(212,198,181,.88);
  box-shadow:var(--tb-shadow-soft);
  background:linear-gradient(180deg, #ffffff 0%, #faf5ef 100%);
}

/* Mobile: preserve density, but keep the cleaner staging */
@media (max-width: 900px){
  main{
    padding:12px 12px 18px;
  }

  #menuWrap{
    gap:14px;
  }

  #quickBar{
    padding:12px !important;
  }

  #menuWrap .grid{
    gap:10px;
    padding:2px 12px 12px;
  }
}

@media (max-width: 720px){
  .tbHeader{
    gap:10px;
    padding:10px 12px;
  }

  .tbHeader .adminIconBtn,
  .tbHeader .badge,
  .tbHeader #btnHome{
    border-radius:15px;
  }

  .tbHeader .adminIconBtn{
    min-width:48px;
    height:48px;
    padding:0 10px;
  }

  .tbHeader .adminIconBtn img{
    height:30px;
  }

  .tbHeader .badge{
    min-height:48px;
    padding:0 14px;
    font-size:15px;
  }

  .tbHeader #btnHome{
    min-width:88px;
    height:48px;
    padding:0 14px;
    font-size:15px;
  }

  #quickBar .quickBtn{
    min-height:68px;
    padding:10px 8px;
  }

  #menuWrap .tabs{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
    padding:0 12px 12px;
  }

  #menuWrap .tabs .tab{
    min-height:46px;
    padding:9px 8px;
    font-size:13px;
  }

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

  #menuWrap .grid .item{
    min-height:90px;
    padding:14px 10px;
    border-radius:15px;
  }

  #menuWrap .grid .item .name{
    font-size:17px;
  }

  #tableList,
  .cart,
  .footerBtns{
    padding-left:12px;
    padding-right:12px;
  }

  .tableBtn{
    min-height:74px;
    padding:16px;
    border-radius:16px;
  }
}

/* Keep Döner profile intentionally tighter */
@media (max-width: 900px){
  body.profile-doener-counter-menu #quickBar,
  body.profile-doener-counter-menu #menuWrap .tabs,
  body.profile-doener-counter-menu #menuWrap .grid{
    border-radius:14px 14px 0 0;
  }

  body.profile-doener-counter-menu #quickBar .quickBtn,
  body.profile-doener-counter-menu #menuWrap .grid .item,
  body.profile-doener-counter-menu #menuWrap .tabs .tab{
    box-shadow:none;
  }
}

/* ===== TableBon Design Refresh v2 ===== */
/* Focus: stronger header, visible Home button, sharper tabs, more premium item cards */

:root{
  --tb2-header-shadow:0 12px 26px rgba(24,20,17,.08);
  --tb2-card-shadow:0 16px 34px rgba(24,20,17,.08);
  --tb2-card-shadow-strong:0 20px 44px rgba(24,20,17,.11);
  --tb2-accent-strong:#b96338;
  --tb2-accent-soft:#f6e4d9;
  --tb2-tab-surface:#f1e8dd;
  --tb2-tab-stroke:#d8c7b4;
}

.tbHeader{
  gap:16px;
  padding:14px 18px 16px;
  background:
    linear-gradient(180deg, rgba(250,246,240,.96) 0%, rgba(244,239,231,.92) 100%);
  border-bottom:1px solid rgba(201,186,168,.95);
  box-shadow:var(--tb2-header-shadow);
}

.tbHeader .adminIconBtn{
  border:1px solid rgba(209,194,176,.96);
  background:linear-gradient(180deg, #fffdf9 0%, #f5ecdf 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,.88) inset,
    0 8px 18px rgba(24,20,17,.06);
}

.tbHeader .badge{
  border-color:rgba(206,190,170,.96);
  background:linear-gradient(180deg, #fffdf9 0%, #f7efe5 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,.94) inset,
    0 8px 18px rgba(24,20,17,.05);
  font-size:17px;
  font-weight:900;
  letter-spacing:.01em;
}

.tbHeader #btnHome{
  min-width:132px;
  height:56px;
  padding:0 22px;
  border-radius:18px;
  border:1px solid var(--tb2-accent-strong);
  background:linear-gradient(180deg, #d47a48 0%, var(--accent) 100%);
  color:#fffdf9;
  box-shadow:
    0 1px 0 rgba(255,255,255,.16) inset,
    0 10px 22px rgba(196,106,58,.28);
  font-weight:900;
  text-shadow:0 1px 0 rgba(0,0,0,.08);
}

@media (hover:hover){
  .tbHeader #btnHome:hover{
    transform:translateY(-1px);
    box-shadow:
      0 1px 0 rgba(255,255,255,.16) inset,
      0 14px 28px rgba(196,106,58,.32);
  }
}

.tbHeader #btnHome:active{
  transform:translateY(1px);
}

#quickBar{
  margin-top:12px !important;
  padding:14px 14px 10px !important;
  border-radius:20px 20px 0 0;
  background:linear-gradient(180deg, #f6efe6 0%, #f1e7db 100%);
  box-shadow:inset 0 -1px 0 rgba(212,198,181,.55);
}

#menuWrap .tabs{
  padding:10px;
  border-bottom:none;
  background:linear-gradient(180deg, #f7f1e9 0%, #f2e8dc 100%);
  box-shadow:inset 0 -1px 0 rgba(212,198,181,.55);
}

#menuWrap .tabs .tab{
  min-height:48px;
  padding:11px 12px;
  border-radius:16px;
  border:1px solid transparent;
  background:rgba(255,255,255,.52);
  color:#4f4841;
  box-shadow:none;
  transition:
    transform .14s ease,
    background-color .14s ease,
    border-color .14s ease,
    box-shadow .14s ease,
    color .14s ease;
}

#menuWrap .tabs .tab.active{
  background:linear-gradient(180deg, #d57c4b 0%, var(--accent) 100%);
  color:#fffdf9;
  border-color:var(--tb2-accent-strong);
  box-shadow:
    0 1px 0 rgba(255,255,255,.16) inset,
    0 10px 22px rgba(196,106,58,.22);
}

@media (hover:hover){
  #menuWrap .tabs .tab:hover{
    background:#fffdfa;
    border-color:var(--tb2-tab-stroke);
    color:var(--text);
    box-shadow:0 8px 18px rgba(24,20,17,.05);
  }

  #menuWrap .tabs .tab.active:hover{
    background:linear-gradient(180deg, #da8150 0%, #c46a3a 100%);
    color:#fffdf9;
    border-color:var(--tb2-accent-strong);
  }
}

#menuWrap .grid{
  padding:8px 14px 18px;
  gap:16px;
  align-content:start;
}

#menuWrap .grid .item{
  position:relative;
  min-height:114px;
  padding:20px 14px 18px;
  border-radius:20px;
  border:1px solid rgba(212,198,181,.88);
  background:
    radial-gradient(circle at top center, rgba(255,255,255,.92) 0%, rgba(255,255,255,0) 52%),
    linear-gradient(180deg, #fffefd 0%, #f7efe5 100%);
  box-shadow:var(--tb2-card-shadow);
  transition:
    transform .14s ease,
    box-shadow .14s ease,
    border-color .14s ease,
    background .14s ease;
}

#menuWrap .grid .item::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:4px;
  border-radius:20px 20px 0 0;
  background:linear-gradient(90deg, rgba(196,106,58,.18) 0%, rgba(196,106,58,.5) 48%, rgba(196,106,58,.18) 100%);
  opacity:.95;
}

#menuWrap .grid .item .name{
  font-size:20px;
  line-height:1.12;
  letter-spacing:-.01em;
}

#menuWrap .grid .item .meta,
#menuWrap .grid .item .itemHint{
  color:#6e665f;
}

@media (hover:hover){
  #menuWrap .grid .item:hover{
    transform:translateY(-2px);
    border-color:rgba(196,106,58,.34);
    box-shadow:var(--tb2-card-shadow-strong);
  }
}

#menuWrap .grid .item:active{
  transform:translateY(1px);
}

@media (max-width: 720px){
  .tbHeader{
    gap:10px;
    padding:10px 12px 12px;
  }

  .tbHeader .badge{
    min-height:48px;
    padding:0 14px;
    font-size:15px;
  }

  .tbHeader #btnHome{
    min-width:96px;
    height:48px;
    padding:0 16px;
    font-size:15px;
    border-radius:16px;
  }

  #quickBar{
    padding:12px 12px 8px !important;
  }

  #menuWrap .tabs{
    padding:8px;
    gap:8px;
  }

  #menuWrap .tabs .tab{
    min-height:44px;
    padding:9px 8px;
    font-size:13px;
    border-radius:14px;
  }

  #menuWrap .grid{
    gap:12px;
    padding:8px 12px 14px;
  }

  #menuWrap .grid .item{
    min-height:94px;
    padding:16px 10px 14px;
    border-radius:16px;
  }

  #menuWrap .grid .item::before{
    height:3px;
    border-radius:16px 16px 0 0;
  }

  #menuWrap .grid .item .name{
    font-size:17px;
  }
}

/* Döner profile remains tighter despite the stronger second pass */
@media (min-width: 721px) and (max-width: 1180px){
  body.profile-doener-counter-menu .tbHeader #btnHome{
    min-width:84px;
    min-height:42px;
    height:42px;
    padding:0 12px;
    font-size:14px;
    border-radius:12px;
  }

  body.profile-doener-counter-menu #menuWrap .tabs .tab{
    min-height:40px;
    padding:8px 8px;
    border-radius:12px;
  }

  body.profile-doener-counter-menu #menuWrap .grid .item{
    min-height:92px;
    padding:14px 10px 12px;
    border-radius:14px;
  }

  body.profile-doener-counter-menu #menuWrap .grid .item .name{
    font-size:17px;
  }
}

/* ===== TableBon Design Refresh v3 ===== */
/* Focus: premium cart / total area, without changing the mobile stacking model */

:root{
  --tb3-cart-surface:#fbf7f1;
  --tb3-cart-surface-2:#f6eee4;
  --tb3-cart-stroke:#d8c7b5;
  --tb3-cart-shadow:0 14px 30px rgba(24,20,17,.07);
  --tb3-cart-shadow-soft:0 8px 18px rgba(24,20,17,.05);
  --tb3-qty-surface:#f3e7da;
}

.cart{
  position:relative;
  padding:16px 16px 10px;
}

#cartSub{
  margin-bottom:14px;
  padding:14px 16px;
  border:1px solid rgba(216,199,181,.92);
  border-radius:18px;
  background:
    linear-gradient(180deg, #fffdf9 0%, var(--tb3-cart-surface) 100%);
  box-shadow:var(--tb3-cart-shadow-soft);
  font-weight:900;
  line-height:1.25;
}

.cartRow,
.cartLine{
  padding:0;
  border-bottom:none;
}

.cartRow{
  margin-bottom:10px;
}

.cartRow:last-child,
.cartLine:last-child{
  margin-bottom:0;
}

.cartSwipeContent,
.cartLine{
  padding:14px 14px;
  border:1px solid rgba(216,199,181,.88);
  border-radius:18px;
  background:
    linear-gradient(180deg, #fffefd 0%, var(--tb3-cart-surface) 100%);
  box-shadow:var(--tb3-cart-shadow-soft);
}

.cartSwipeContent{
  min-height:76px;
}

.cartLeft{
  display:grid;
  gap:4px;
}

.cartName{
  font-size:17px;
  line-height:1.18;
  letter-spacing:-.01em;
}

.cartNote{
  display:inline-block;
  margin-top:2px;
  padding:6px 9px;
  border-radius:10px;
  background:rgba(239,231,220,.75);
  color:#6b635b;
  font-size:12px;
  line-height:1.35;
}

.cartRight{
  gap:10px;
  align-items:center;
}

.cartRight .btn{
  min-width:42px;
  min-height:42px;
  padding:0 12px;
  border-radius:12px;
  border-color:rgba(216,199,181,.92);
  background:linear-gradient(180deg, #fffefd 0%, #f7efe5 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.82) inset;
}

.qty{
  min-width:40px;
  padding:9px 10px;
  border-radius:12px;
  border-color:rgba(214,192,171,.95);
  background:linear-gradient(180deg, #fffdf9 0%, var(--tb3-qty-surface) 100%);
  font-weight:900;
  box-shadow:0 1px 0 rgba(255,255,255,.84) inset;
}

.footerBtns{
  gap:12px;
  padding:14px 16px 18px;
  border-top:1px solid rgba(216,199,181,.7);
  background:
    linear-gradient(180deg, rgba(255,253,249,.06) 0%, rgba(255,250,245,.9) 28%, rgba(255,250,245,1) 100%);
}

.footerBtns .btn{
  min-height:58px;
  border-radius:18px;
  font-weight:900;
  box-shadow:var(--tb3-cart-shadow-soft);
}

.footerBtns .btn:not(.primary):not(.danger){
  background:linear-gradient(180deg, #fffefd 0%, #f7efe5 100%);
  border-color:rgba(216,199,181,.92);
}

.footerBtns .btn.primary{
  border-color:var(--tb2-accent-strong);
  background:linear-gradient(180deg, #d57d4b 0%, var(--accent) 100%);
  color:#fffdf9;
  box-shadow:
    0 1px 0 rgba(255,255,255,.16) inset,
    0 12px 24px rgba(196,106,58,.24);
}

.footerBtns .btn.danger{
  border-color:#d9b1a9;
  background:linear-gradient(180deg, #fbefeb 0%, #f5ddd8 100%);
}

@media (hover:hover){
  .cartSwipeContent:hover,
  .cartLine:hover{
    border-color:rgba(196,106,58,.24);
    box-shadow:var(--tb3-cart-shadow);
  }

  .footerBtns .btn:hover,
  .cartRight .btn:hover{
    transform:translateY(-1px);
  }
}

@media (max-width: 900px){
  .cart{
    padding:14px 14px 10px;
  }

  #cartSub{
    margin-bottom:12px;
  }

  .footerBtns{
    padding:12px 14px 16px;
  }
}

@media (max-width: 720px){
  .cart{
    padding:12px 12px 8px;
  }

  #cartSub{
    margin-bottom:10px;
    padding:12px 14px;
    border-radius:16px;
  }

  .cartRow{
    margin-bottom:8px;
  }

  .cartSwipeContent,
  .cartLine{
    padding:12px 12px;
    border-radius:16px;
  }

  .cartSwipeContent{
    min-height:72px;
  }

  .cartName{
    font-size:16px;
  }

  .cartNote{
    font-size:12px;
    padding:5px 8px;
  }

  .cartRight{
    gap:8px;
  }

  .cartRight .btn{
    min-width:40px;
    min-height:40px;
    border-radius:11px;
  }

  .qty{
    min-width:38px;
    padding:8px 9px;
    border-radius:11px;
  }

  .footerBtns{
    gap:10px;
    padding:12px 12px 14px;
  }

  .footerBtns .btn{
    min-height:54px;
    border-radius:16px;
  }
}

/* Döner profile stays deliberately compact */
@media (min-width: 721px) and (max-width: 1180px){
  body.profile-doener-counter-menu .cart{
    padding:10px 10px 8px;
  }

  body.profile-doener-counter-menu #cartSub{
    margin-bottom:8px;
    padding:10px 12px;
    border-radius:13px;
  }

  body.profile-doener-counter-menu .cartRow{
    margin-bottom:6px;
  }

  body.profile-doener-counter-menu .cartSwipeContent,
  body.profile-doener-counter-menu .cartLine{
    min-height:auto;
    padding:10px 10px;
    border-radius:13px;
  }

  body.profile-doener-counter-menu .cartName{
    font-size:15px;
  }

  body.profile-doener-counter-menu .cartRight .btn{
    min-width:36px;
    min-height:36px;
  }

  body.profile-doener-counter-menu .qty{
    min-width:34px;
    padding:7px 8px;
  }

  body.profile-doener-counter-menu .footerBtns{
    gap:8px;
    padding:10px;
  }

  body.profile-doener-counter-menu .footerBtns .btn{
    min-height:46px;
    border-radius:12px;
  }
}

/* ===== TableBon Design Refresh v4 ===== */
/* Focus: modal / variant / form finishing pass, without changing existing flow */

:root{
  --tb4-modal-shadow:0 24px 56px rgba(24,20,17,.16);
  --tb4-modal-shadow-soft:0 12px 26px rgba(24,20,17,.08);
  --tb4-focus-ring:0 0 0 4px rgba(196,106,58,.12);
  --tb4-field-surface:#fffdfa;
  --tb4-field-surface-2:#f7efe5;
  --tb4-field-stroke:#d9c9b7;
}

.modalBack{
  background:rgba(24,20,17,.34);
  backdrop-filter:blur(10px);
}

.modal{
  width:min(680px, 100%);
  border:1px solid rgba(217,201,183,.96);
  border-radius:24px;
  background:
    radial-gradient(circle at top center, rgba(255,255,255,.78) 0%, rgba(255,255,255,0) 42%),
    linear-gradient(180deg, #fffdf9 0%, #f8f1e8 100%);
  box-shadow:var(--tb4-modal-shadow);
}

.modal header{
  padding:16px 18px;
  background:linear-gradient(180deg, #fffdf9 0%, #f6eee4 100%);
  border-bottom:1px solid rgba(217,201,183,.88);
}

.modal .body{
  padding:18px;
  background:linear-gradient(180deg, rgba(255,253,249,.4) 0%, rgba(248,241,232,.88) 100%);
}

.modal .footerBtns{
  padding:14px 18px 18px;
  border-top:1px solid rgba(217,201,183,.62);
  background:linear-gradient(180deg, rgba(255,253,249,.04) 0%, rgba(255,249,243,.96) 28%, rgba(255,249,243,1) 100%);
}

.modal .footerBtns .btn{
  min-height:54px;
  border-radius:16px;
  font-weight:900;
  box-shadow:var(--tb4-modal-shadow-soft);
}

.field{
  gap:7px;
}

.field label{
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#6a625a;
}

.field input,
.field select,
.field textarea,
.input,
.select,
.textarea{
  min-height:50px;
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(217,201,183,.96);
  background:linear-gradient(180deg, var(--tb4-field-surface) 0%, var(--tb4-field-surface-2) 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.86) inset;
  transition:border-color .14s ease, box-shadow .14s ease, background-color .14s ease;
}

.field textarea,
.textarea,
.modal textarea{
  min-height:118px;
}

.field input:focus,
.field select:focus,
.field textarea:focus,
.input:focus,
.select:focus,
.textarea:focus{
  border-color:var(--accent);
  box-shadow:0 1px 0 rgba(255,255,255,.86) inset, var(--tb4-focus-ring);
  background:#fffdf9;
}

.variantOptions{
  gap:10px !important;
  margin-top:6px;
}

.variantOptions .variantOptionBtn,
.variantOptions .btn{
  min-height:58px;
  padding:12px 10px;
  border-radius:16px;
  border:1px solid rgba(217,201,183,.96);
  background:linear-gradient(180deg, #fffdf9 0%, #f5ecdf 100%);
  color:var(--text);
  font-weight:800;
  line-height:1.15;
  box-shadow:0 1px 0 rgba(255,255,255,.84) inset, var(--tb4-modal-shadow-soft);
  transition:transform .14s ease, border-color .14s ease, box-shadow .14s ease, background .14s ease, color .14s ease;
}

.variantOptions .variantOptionBtn.active,
.variantOptions .variantOptionBtn.is-selected,
.variantOptions .variantOptionBtn.selected,
.variantOptions .variantOptionBtn[aria-pressed="true"],
.variantOptions .btn.primary,
.variantOptions .btn.active,
.variantOptions .btn.is-selected,
.variantOptions .btn.selected,
.variantOptions .btn[aria-pressed="true"]{
  border-color:var(--tb2-accent-strong);
  background:linear-gradient(180deg, #d57d4b 0%, var(--accent) 100%);
  color:#fffdf9;
  box-shadow:0 1px 0 rgba(255,255,255,.16) inset, 0 12px 24px rgba(196,106,58,.22);
}

@media (hover:hover){
  .variantOptions .variantOptionBtn:hover,
  .variantOptions .btn:hover,
  .modal .footerBtns .btn:hover{
    transform:translateY(-1px);
  }

  .field input:hover,
  .field select:hover,
  .field textarea:hover,
  .input:hover,
  .select:hover,
  .textarea:hover{
    border-color:rgba(196,106,58,.34);
  }
}

@media (max-width: 720px){
  .modalBack{
    padding:10px;
  }

  .modal{
    width:min(100%, calc(100vw - 20px));
    max-height:calc(100vh - 24px);
    border-radius:20px;
  }

  .modal header{
    padding:14px 14px;
  }

  .modal .body{
    padding:14px;
    max-height:calc(100vh - 136px);
  }

  .modal .footerBtns{
    padding:12px 14px 14px;
    gap:10px;
  }

  .modal .footerBtns .btn{
    min-height:52px;
    border-radius:15px;
  }

  .field input,
  .field select,
  .field textarea,
  .input,
  .select,
  .textarea{
    min-height:48px;
    padding:12px 13px;
    border-radius:15px;
  }

  .field textarea,
  .textarea,
  .modal textarea{
    min-height:110px;
  }

  .variantOptions{
    gap:8px !important;
    margin-top:4px;
  }

  .variantOptions .variantOptionBtn,
  .variantOptions .btn{
    min-height:52px;
    padding:10px 8px;
    border-radius:14px;
    font-size:13px;
  }
}

/* Döner profile keeps compact interaction targets in modal-heavy flows */
@media (min-width: 721px) and (max-width: 1180px){
  body.profile-doener-counter-menu .modal{
    border-radius:18px;
  }

  body.profile-doener-counter-menu .modal header,
  body.profile-doener-counter-menu .modal .body,
  body.profile-doener-counter-menu .modal .footerBtns{
    padding-left:14px;
    padding-right:14px;
  }

  body.profile-doener-counter-menu .variantOptions .variantOptionBtn,
  body.profile-doener-counter-menu .variantOptions .btn{
    min-height:48px;
    padding:9px 8px;
    border-radius:12px;
    font-size:13px;
    box-shadow:none;
  }
}


/* vNext: restore stronger button glow feedback */
.item,
.quickBtn{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

.item::before,
.quickBtn::before{
  content:"";
  position:absolute;
  inset:-16%;
  border-radius:inherit;
  background:radial-gradient(circle at 50% 50%, rgba(196,106,58,.42) 0%, rgba(196,106,58,.24) 34%, rgba(196,106,58,.12) 56%, rgba(196,106,58,0) 78%);
  opacity:0;
  transform:scale(.78);
  pointer-events:none;
  z-index:1;
}

.item.is-added::before,
.quickBtn.is-added::before{
  animation:tbAddGlow 430ms ease-out;
}

@keyframes tbAddGlow{
  0%{
    opacity:0;
    transform:scale(.78);
  }
  22%{
    opacity:1;
    transform:scale(.98);
  }
  52%{
    opacity:.72;
    transform:scale(1.10);
  }
  100%{
    opacity:0;
    transform:scale(1.28);
  }
}


.badge.cartCountPulse,
#hdrTable.cartCountPulse{
  animation: tbHeaderBadgePulse 420ms cubic-bezier(.22,.9,.24,1);
}

#hdrTable{
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

#hdrTable::before{
  content: "";
  position: absolute;
  inset: -24%;
  border-radius: inherit;
  background: radial-gradient(circle at 50% 50%, rgba(196,106,58,.42) 0%, rgba(196,106,58,.24) 38%, rgba(196,106,58,.10) 60%, rgba(196,106,58,0) 78%);
  opacity: 0;
  transform: scale(.82);
  pointer-events: none;
  z-index: 0;
}

#hdrTable::after{
  content: "";
  position: absolute;
  inset: -18%;
  border-radius: inherit;
  background: linear-gradient(115deg, rgba(255,255,255,0) 18%, rgba(255,255,255,.18) 38%, rgba(255,255,255,.58) 50%, rgba(255,255,255,.18) 62%, rgba(255,255,255,0) 82%);
  transform: translateX(-140%) skewX(-18deg);
  opacity: 0;
  pointer-events: none;
  z-index: 1;
}

#hdrTable.cartCountPulse::before{
  animation: tbHeaderBadgeGlow 420ms ease-out;
}

#hdrTable.cartCountPulse::after{
  opacity: 1;
  animation: tbHeaderBadgeSweep 420ms ease-out;
}

@keyframes tbHeaderBadgePulse{
  0%{
    transform: scale(1);
    border-color: var(--stroke);
    box-shadow: 0 1px 0 rgba(255,255,255,.6) inset;
  }
  24%{
    transform: scale(.95);
    border-color: rgba(196,106,58,.62);
    box-shadow: 0 0 0 1px rgba(196,106,58,.14), 0 0 0 8px rgba(196,106,58,.08), 0 1px 0 rgba(255,255,255,.6) inset;
  }
  58%{
    transform: scale(1.06);
    border-color: rgba(196,106,58,.78);
    box-shadow: 0 0 0 1px rgba(196,106,58,.20), 0 0 0 10px rgba(196,106,58,.12), 0 8px 22px rgba(196,106,58,.16), 0 1px 0 rgba(255,255,255,.6) inset;
  }
  100%{
    transform: scale(1);
    border-color: var(--stroke);
    box-shadow: 0 1px 0 rgba(255,255,255,.6) inset;
  }
}

@keyframes tbHeaderBadgeGlow{
  0%{
    opacity: 0;
    transform: scale(.82);
  }
  30%{
    opacity: 1;
    transform: scale(1.02);
  }
  100%{
    opacity: 0;
    transform: scale(1.24);
  }
}

@keyframes tbHeaderBadgeSweep{
  0%{
    transform: translateX(-140%) skewX(-18deg);
  }
  100%{
    transform: translateX(138%) skewX(-18deg);
  }
}

.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
