:root {
  --ink: #24302e;
  --muted: #66736f;
  --paper: #f6f5f0;
  --surface: #ffffff;
  --line: #dedfd6;
  --green: #2b5b56;
  --green-dark: #1f4541;
  --sand: #f0eadb;
  --orange: #cc8254;
  --danger: #a94742;
  --success: #3e7a57;
  --shadow: 0 14px 38px rgba(24, 39, 35, 0.09);
  --radius: 18px;
  --radius-small: 12px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { min-height: 100%; background: var(--paper); }
body { margin: 0; min-height: 100%; background: var(--paper); color: var(--ink); font-size: 15px; line-height: 1.5; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 262px minmax(0, 1fr); }
.sidebar { position: sticky; top: 0; height: 100vh; display: flex; flex-direction: column; padding: 24px 16px; background: #173f3b; color: #eff7f3; }
.brand { display: flex; align-items: center; gap: 12px; padding: 10px 10px 28px; }
.brand-mark { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 14px; background: #ecb980; color: #173f3b; font-size: 22px; box-shadow: inset 0 0 0 1px rgba(255,255,255,.15); }
.brand strong { display: block; font-size: 20px; letter-spacing: -.04em; }
.brand small { display: block; color: rgba(239,247,243,.72); font-size: 12px; }
.nav-list { display: grid; gap: 6px; }
.nav-list a { display: flex; align-items: center; gap: 12px; padding: 11px 12px; color: rgba(239,247,243,.78); border-radius: 11px; transition: .18s ease; }
.nav-list a:hover, .nav-list a.active { color: #fff; background: rgba(255,255,255,.13); }
.nav-list a span { width: 20px; text-align: center; color: #ecb980; font-size: 17px; }
.sidebar-note { margin-top: auto; padding: 14px; border: 1px solid rgba(255,255,255,.15); border-radius: 15px; background: rgba(255,255,255,.06); }
.sidebar-note strong { font-size: 13px; color: #f3ca94; }
.sidebar-note p { margin: 5px 0 0; color: rgba(239,247,243,.72); font-size: 12px; }
.logout-form { margin-top: 14px; padding: 0 10px; }
.text-button { padding: 0; border: 0; background: none; color: rgba(239,247,243,.7); font-size: 13px; }
.text-button:hover { color: #fff; }

.main-content { min-width: 0; padding: 28px clamp(20px, 4vw, 52px) 52px; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 28px; }
.topbar-actions { display: flex; align-items: center; justify-content: flex-end; gap: 12px; }
.top-total { min-width: 168px; padding: 9px 13px 10px; border: 1px solid #cfe0d5; border-radius: 13px; background: linear-gradient(135deg, #f2f8f3, #fffaf0); box-shadow: 0 6px 18px rgba(35, 67, 54, .06); text-align: right; }
.top-total span, .top-total small { display: block; color: #6d7e75; font-size: 10px; font-weight: 800; letter-spacing: .055em; text-transform: uppercase; }
.top-total strong { display: block; margin: 1px 0 1px; color: var(--green); font-size: 20px; line-height: 1.08; letter-spacing: -.04em; }
.top-total small { color: #8b968f; font-size: 9px; letter-spacing: .025em; text-transform: none; }
.topbar h1 { margin: 2px 0 0; font-size: clamp(25px, 3vw, 35px); letter-spacing: -.045em; line-height: 1.1; }
.eyebrow { margin: 0; color: #75807a; font-size: 11px; line-height: 1.1; letter-spacing: .14em; font-weight: 700; }

.button { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 42px; padding: 10px 15px; border: 1px solid transparent; border-radius: 11px; font-weight: 700; font-size: 14px; transition: transform .12s ease, background .12s ease, border .12s ease; }
.button:hover { transform: translateY(-1px); }
.button-primary { background: var(--green); color: #fff; box-shadow: 0 8px 20px rgba(43,91,86,.16); }
.button-primary:hover { background: var(--green-dark); }
.button-secondary { background: #fff; color: var(--green); border-color: #cbd9d6; }
.button-secondary:hover { background: #f3f9f7; }
.button-ghost { background: transparent; color: #50615b; border-color: var(--line); }
.button-danger { background: #fff1ef; color: var(--danger); border-color: #efc3bf; }
.button-full { width: 100%; }
.text-link { color: var(--green); font-weight: 700; font-size: 13px; }
.text-link:hover { text-decoration: underline; }

.flash { margin: -8px 0 20px; padding: 12px 14px; border-radius: 11px; font-weight: 600; font-size: 14px; border: 1px solid transparent; }
.flash-success { color: #195336; background: #eaf6ee; border-color: #b9dfc5; }
.flash-error { color: #8a312d; background: #fff0ee; border-color: #edc0bb; }
.flash-warning { color: #6e5517; background: #fff8dc; border-color: #e8d58b; }

.intro-panel, .budget-card { display: flex; align-items: center; justify-content: space-between; gap: 28px; padding: 27px 28px; margin-bottom: 20px; border: 1px solid #d9ded6; border-radius: var(--radius); background: linear-gradient(118deg, #eef2ec, #f7f4ea); box-shadow: var(--shadow); }
.intro-panel h2, .budget-card h2 { margin: 5px 0 6px; font-size: clamp(21px, 3vw, 29px); letter-spacing: -.04em; }
.intro-panel p:not(.eyebrow), .budget-card p:not(.eyebrow) { margin: 0; color: #57635e; }

.stats-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; margin-bottom: 20px; }
.stat-card { min-height: 128px; padding: 18px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-small); box-shadow: 0 5px 18px rgba(24,39,35,.035); }
.stat-card span { display: block; color: #708078; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.stat-card strong { display: block; margin: 4px 0 4px; font-size: 32px; line-height: 1; letter-spacing: -.055em; }
.stat-card small { color: #6e7874; font-size: 12px; }

.budget-card { display: grid; grid-template-columns: minmax(0, 1fr) minmax(200px, 40%); }
.progress-shell { overflow: hidden; height: 12px; border-radius: 999px; background: rgba(43,91,86,.14); }
.progress-shell span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--green), #78a26d); }

.two-column { display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(0, .88fr); gap: 20px; }
.panel { padding: 22px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 6px 20px rgba(24,39,35,.035); }
.panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.panel-head h2 { margin: 4px 0 0; font-size: 20px; letter-spacing: -.035em; }
.compact-list { display: grid; gap: 4px; }
.compact-item { display: grid; grid-template-columns: 8px minmax(0,1fr) auto auto; align-items: center; gap: 10px; padding: 12px 0; border-bottom: 1px solid #ecede8; }
.compact-item:last-child { border-bottom: 0; }
.priority-dot { width: 8px; height: 8px; border-radius: 50%; background: #b1b7b4; }
.priority-high { background: #d46e53; color: #a24736; }
.priority-normal { background: #e2a544; color: #9a6916; }
.priority-low { background: #6e9b85; color: #39715a; }
.compact-item-main { min-width: 0; }
.compact-item-title { display: block; width: fit-content; max-width: 100%; }
.compact-item-title:hover strong { color: var(--green); }
.compact-item-main strong { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 14px; }
.compact-item-main small { display: block; overflow: hidden; color: #7a847f; font-size: 12px; text-overflow: ellipsis; white-space: nowrap; }
.compact-product-link { display: inline-flex; margin-top: 5px; color: var(--green); font-size: 11px; font-weight: 800; }
.compact-product-link:hover { color: var(--green-dark); text-decoration: underline; }
.compact-price { color: #3d4b46; font-size: 13px; font-weight: 700; white-space: nowrap; }
.badge { display: inline-flex; align-items: center; justify-content: center; width: fit-content; padding: 4px 7px; border-radius: 999px; font-size: 10px; font-weight: 800; letter-spacing: .03em; white-space: nowrap; }
.status-planned { background: #edf0ee; color: #617069; }
.status-ordered { background: #fff2d9; color: #956119; }
.status-completed { background: #e5f4e9; color: #2d6d46; }
.status-cancelled { background: #f8e9e8; color: #9a4945; }

.empty-state { display: grid; justify-items: center; padding: 28px 14px; text-align: center; color: #69756f; }
.empty-state > span { display: grid; place-items: center; width: 42px; height: 42px; margin-bottom: 7px; border-radius: 50%; background: #edf3ee; color: var(--green); font-size: 22px; }
.empty-state h3, .empty-state h2 { margin: 0 0 4px; color: #37443f; font-size: 16px; }
.empty-state p { max-width: 380px; margin: 0; font-size: 13px; }
.large-empty { min-height: 310px; align-content: center; }
.large-empty .button { margin-top: 16px; }

.category-chart { display: grid; gap: 10px; }
.category-row { display: grid; grid-template-columns: 11px minmax(0,1fr) auto auto; align-items: center; gap: 9px; }
.category-swatch { width: 10px; height: 10px; border-radius: 4px; }
.category-swatch.large { width: 17px; height: 17px; }
.category-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 13px; font-weight: 650; }
.category-count { display: inline-flex; min-width: 20px; padding: 1px 5px; justify-content: center; border-radius: 999px; background: #f0f1ed; color: #6c7772; font-size: 11px; font-weight: 700; }
.category-row strong { font-size: 13px; }

.filter-panel { padding: 13px; margin-bottom: 20px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); }
.filter-form { display: grid; grid-template-columns: minmax(250px,1fr) 150px 170px auto auto; align-items: center; gap: 9px; }
.search-field { position: relative; display: block; }
.search-field span { position: absolute; top: 50%; left: 13px; color: #6c7772; transform: translateY(-50%); font-size: 20px; }
.search-field input { padding-left: 36px; }
.filter-reset { padding: 8px 6px; text-align: center; }

.item-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.item-card { position: relative; overflow: hidden; display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: 0 6px 20px rgba(24,39,35,.035); transition: transform .15s ease, box-shadow .15s ease; }
.item-card:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(24,39,35,.09); }
.item-card-link { display: flex; flex: 1; flex-direction: column; }
.item-image { position: relative; overflow: hidden; aspect-ratio: 1.58 / 1; background: #eff3ef; }
.item-image img, .preview-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.item-image .badge { position: absolute; top: 10px; right: 10px; box-shadow: 0 2px 6px rgba(0,0,0,.08); }
.item-image-placeholder, .preview-image.item-image-placeholder { display: grid; place-items: center; background: linear-gradient(135deg, #dae3da, #f4eedf); color: #496762; }
.item-image-placeholder span { font-size: 38px; }
.item-card-body { padding: 15px 15px 12px; }
.item-card-title { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.item-card-title h2 { margin: 0; font-size: 16px; line-height: 1.25; letter-spacing: -.025em; }
.priority-label { padding: 3px 6px; border-radius: 7px; font-size: 10px; font-weight: 800; white-space: nowrap; }
.item-meta { min-height: 20px; margin: 7px 0 12px; overflow: hidden; color: #718079; font-size: 12px; text-overflow: ellipsis; white-space: nowrap; }
.item-card-bottom { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.item-card-bottom strong { font-size: 17px; letter-spacing: -.025em; }
.item-card-bottom span { color: #75807a; font-size: 11px; }
.item-card-actions { display: flex; align-items: stretch; border-top: 1px solid #edf0ea; background: #f8faf7; }
.item-product-link, .quick-action button { display: flex; align-items: center; justify-content: center; min-height: 42px; padding: 10px; color: var(--green); border: 0; background: transparent; font-size: 12px; font-weight: 800; }
.item-product-link { flex: 1; border-right: 1px solid #edf0ea; }
.item-product-link:hover, .quick-action button:hover { background: #edf5ef; }
.quick-action { display: flex; flex: 1; }
.quick-action button { width: 100%; }
.product-link-helper { display: inline-flex; align-items: center; width: fit-content; margin-top: -2px; color: var(--green); font-size: 13px; font-weight: 800; }
.product-link-helper:hover { color: var(--green-dark); text-decoration: underline; }
.preview-product-link { width: 100%; margin-top: 14px; }

.form-layout { display: grid; grid-template-columns: minmax(0, 1fr) 270px; gap: 20px; align-items: start; }
.item-form { padding: 28px; }
.form-grid { display: grid; gap: 14px; }
.form-grid.two { grid-template-columns: repeat(2, minmax(0,1fr)); }
.form-grid.three { grid-template-columns: repeat(3, minmax(0,1fr)); }
.span-two { grid-column: span 2; }
label { display: grid; gap: 6px; color: #48544f; font-size: 13px; font-weight: 750; }
label small { color: #74807a; font-size: 11px; font-weight: 500; }
.required { color: var(--danger); }
input, select, textarea { width: 100%; padding: 10px 11px; color: #28342f; outline: 0; border: 1px solid #cfd6d0; border-radius: 10px; background: #fff; font-size: 14px; transition: border-color .15s ease, box-shadow .15s ease; }
textarea { resize: vertical; min-height: 108px; }
input:focus, select:focus, textarea:focus { border-color: #57857d; box-shadow: 0 0 0 3px rgba(43,91,86,.11); }
input[type="file"] { padding: 8px; background: #fafbf8; font-size: 12px; }
input[type="color"] { min-height: 42px; padding: 3px; }
.checkbox-row { display: flex; align-items: center; gap: 8px; font-weight: 600; }
.checkbox-row input { width: 16px; height: 16px; }
.form-divider { height: 1px; margin: 23px 0; background: #e7e9e4; }
.price-preview { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; margin: 14px 0 19px; border-radius: 10px; background: #eff5ef; color: #4b5b55; font-size: 13px; }
.price-preview strong { color: var(--green); font-size: 18px; }
.form-actions { display: flex; align-items: center; justify-content: flex-end; gap: 10px; margin-top: 24px; }
.side-preview { display: grid; gap: 14px; }
.preview-card { padding: 17px; }
.preview-image { overflow: hidden; display: grid; place-items: center; aspect-ratio: 1.4 / 1; margin: 10px 0 14px; border-radius: 12px; background: #eff3ef; }
.preview-image.item-image-placeholder span { font-size: 34px; }
.preview-card h2 { margin: 0; font-size: 17px; letter-spacing: -.025em; }
.preview-card p { margin: 4px 0 11px; color: #728079; font-size: 12px; }
.preview-card strong { color: var(--green); font-size: 19px; }
.danger-panel { border-color: #edd1ce; background: #fffafa; }
.danger-panel p:not(.eyebrow) { color: #795b59; font-size: 12px; }

.category-page { grid-template-columns: minmax(280px,.7fr) minmax(0,1.3fr); }
.stack-form { display: grid; gap: 15px; }
.category-management { display: grid; }
.category-manage-row { display: grid; grid-template-columns: 18px minmax(0,1fr) auto; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid #eaede8; }
.category-manage-row:last-child { border-bottom: 0; }
.category-manage-row strong { display: block; font-size: 14px; }
.category-manage-row small { display: block; color: #74807a; font-size: 12px; }
.icon-danger { display: grid; place-items: center; width: 29px; height: 29px; border: 1px solid #ebcfcd; border-radius: 8px; background: #fff5f4; color: var(--danger); font-size: 20px; }
.settings-wrap { display: grid; grid-template-columns: minmax(0,540px); gap: 16px; }
.info-panel code { display: inline-block; padding: 1px 5px; border-radius: 4px; background: #eef1eb; color: #35534e; font-size: .92em; }

.login-page { min-height: 100vh; display: grid; place-items: center; padding: 22px; background: linear-gradient(135deg, #e9efe9, #f6f0e5); }
.login-card { width: min(100%, 420px); padding: 32px; border: 1px solid rgba(255,255,255,.8); border-radius: 22px; background: rgba(255,255,255,.89); box-shadow: 0 20px 60px rgba(37,57,51,.14); }
.login-brand { display: grid; justify-items: center; margin-bottom: 24px; text-align: center; }
.login-brand > span { display: grid; place-items: center; width: 53px; height: 53px; margin-bottom: 8px; border-radius: 17px; background: var(--green); color: #f5d19d; font-size: 27px; }
.login-brand strong { font-size: 23px; letter-spacing: -.05em; }
.login-brand small { color: #74807a; }
.login-card h1 { margin: 0 0 7px; font-size: 25px; letter-spacing: -.04em; }
.login-card > p { margin: 0 0 22px; color: #6c7771; }

@media (max-width: 1180px) {
  .item-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .form-layout { grid-template-columns: minmax(0,1fr) 220px; }
  .filter-form { grid-template-columns: minmax(200px,1fr) 140px 150px auto; }
  .filter-reset { grid-column: 1 / -1; justify-self: end; }
}

@media (max-width: 960px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: static; height: auto; padding: 13px 18px; display: grid; grid-template-columns: auto minmax(0,1fr) auto; align-items: center; gap: 16px; }
  .brand { padding: 0; }
  .brand-mark { width: 37px; height: 37px; font-size: 18px; }
  .brand strong { font-size: 17px; }
  .nav-list { display: flex; justify-content: center; gap: 3px; overflow-x: auto; }
  .nav-list a { padding: 8px 10px; font-size: 13px; white-space: nowrap; }
  .nav-list a span { display: none; }
  .sidebar-note { display: none; }
  .logout-form { margin: 0; padding: 0; }
  .main-content { padding: 24px 22px 42px; }
  .stats-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .two-column { grid-template-columns: 1fr; }
  .form-layout { grid-template-columns: 1fr; }
  .side-preview { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
}

@media (max-width: 650px) {
  .sidebar { grid-template-columns: minmax(0,1fr) auto; }
  .nav-list { grid-column: 1 / -1; justify-content: flex-start; order: 3; margin: 0 -5px; }
  .brand small { display: none; }
  .topbar, .intro-panel { align-items: flex-start; flex-direction: column; }
  .topbar-actions { width: 100%; align-items: stretch; justify-content: space-between; }
  .topbar .button, .intro-panel .button { width: 100%; }
  .main-content { padding: 18px 15px 34px; }
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 9px; }
  .stat-card { min-height: 112px; padding: 14px; }
  .stat-card strong { font-size: 27px; }
  .budget-card { grid-template-columns: 1fr; }
  .panel, .item-form { padding: 17px; }
  .compact-item { grid-template-columns: 8px minmax(0,1fr) auto; }
  .compact-item .badge { grid-column: 2 / -1; justify-self: start; }
  .item-grid { grid-template-columns: 1fr; }
  .filter-form { grid-template-columns: 1fr; }
  .filter-reset { grid-column: auto; justify-self: start; }
  .form-grid.two, .form-grid.three { grid-template-columns: 1fr; }
  .span-two { grid-column: auto; }
  .side-preview { grid-template-columns: 1fr; }
  .category-page { grid-template-columns: 1fr; }
  .form-actions { flex-direction: column-reverse; }
  .form-actions .button { width: 100%; }
  .login-card { padding: 25px 20px; }
}


/* Mobile-first Einkaufsliste und Schnelleingabe – Version 1.1 */
.mobile-tabbar { display: none; }
.items-list-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; padding: 5px 0 16px; }
.items-list-header h2 { margin: 4px 0 3px; font-size: 25px; line-height: 1.12; letter-spacing: -.04em; }
.items-list-header p:not(.eyebrow) { margin: 0; color: var(--muted); font-size: 14px; }
.mobile-list-add { display: none; }
.status-chips { display: flex; gap: 8px; overflow-x: auto; margin: 0 0 12px; padding: 0 1px 4px; scrollbar-width: none; }
.status-chips::-webkit-scrollbar { display: none; }
.status-chips a { flex: 0 0 auto; padding: 9px 13px; border: 1px solid #d9ded8; border-radius: 999px; background: #fff; color: #5b6a64; font-size: 13px; font-weight: 750; }
.status-chips a.active { border-color: var(--green); background: var(--green); color: #fff; }
.filter-panel summary { list-style: none; color: var(--green); cursor: pointer; font-size: 13px; font-weight: 800; }
.filter-panel summary::-webkit-details-marker { display: none; }
.filter-panel summary::after { content: '⌄'; display: inline-block; margin-left: 6px; transition: transform .16s ease; }
.filter-panel[open] summary { margin-bottom: 12px; }
.filter-panel[open] summary::after { transform: rotate(180deg); }
.item-card-tags { display: flex; flex-wrap: wrap; gap: 5px; min-height: 0; margin: -4px 0 10px; }
.item-card-tags span { padding: 3px 7px; border-radius: 7px; background: #f2f4f1; color: #6e7b75; font-size: 10px; font-weight: 700; }
.quick-entry-wrap { width: min(100%, 720px); margin: 0 auto; }
.quick-entry-intro { display: flex; align-items: center; gap: 15px; padding: 8px 2px 19px; }
.quick-entry-icon { display: grid; flex: 0 0 auto; place-items: center; width: 46px; height: 46px; border-radius: 15px; background: var(--green); color: #fff; font-size: 27px; line-height: 1; box-shadow: 0 10px 25px rgba(43,91,86,.22); }
.quick-entry-intro h2 { margin: 3px 0 4px; font-size: 25px; letter-spacing: -.045em; }
.quick-entry-intro p:not(.eyebrow) { margin: 0; color: var(--muted); font-size: 14px; }
.quick-entry-form { display: grid; gap: 15px; padding: 24px; }
.quick-step { display: grid; grid-template-columns: 29px minmax(0, 1fr); align-items: start; gap: 11px; }
.quick-step > span { display: grid; place-items: center; width: 29px; height: 29px; margin-top: 1px; border-radius: 50%; background: #e8f0eb; color: var(--green); font-size: 13px; font-weight: 850; }
.quick-fields { display: grid; gap: 12px; }
.quick-fields.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.quick-fields.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.quick-quantity-note { margin: 10px 0 0; color: #718078; font-size: 12px; line-height: 1.45; }
.quick-quantity-note strong { color: #4c6057; }
.quick-total { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 11px; padding: 11px 12px; border-radius: 10px; background: #eff5ef; color: #4d5f57; font-size: 13px; }
.quick-total strong { color: var(--green); font-size: 18px; }
.quick-image-preview { display: grid; place-items: center; min-height: 116px; overflow: hidden; border: 1px dashed #b9c8c1; border-radius: 12px; background: #f7faf7; color: #76847d; text-align: center; }
.quick-image-preview span { font-size: 28px; }
.quick-image-preview small { display: block; font-size: 11px; font-weight: 700; }
.quick-image-preview img { display: block; width: 100%; height: 100%; min-height: 116px; object-fit: cover; }
.quick-more { margin: 0 0 0 40px; padding: 12px; border: 1px solid #e2e7e1; border-radius: 12px; background: #fbfcfa; }
.quick-more summary { color: var(--green); cursor: pointer; font-size: 13px; font-weight: 800; }
.quick-more[open] summary { margin-bottom: 13px; }
.quick-entry-actions { display: flex; align-items: center; justify-content: flex-end; gap: 10px; margin-top: 3px; }
.quick-entry-help { margin: 0; color: #78847f; font-size: 12px; text-align: center; }
.full-form-link { display: block; margin: 17px 0 5px; text-align: center; }

@media (max-width: 650px) {
  body { padding-bottom: calc(83px + env(safe-area-inset-bottom)); }
  .sidebar { padding: 13px 15px; }
  .sidebar .nav-list, .sidebar-note, .logout-form { display: none; }
  .brand { padding: 0; }
  .brand-mark { width: 39px; height: 39px; border-radius: 13px; }
  .main-content { padding: 17px 14px 22px; }
  .topbar { margin-bottom: 19px; }
  .topbar h1 { font-size: 27px; }
  .topbar-actions { display: block; }
  .top-total { width: 100%; min-width: 0; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 1px 12px; padding: 11px 13px; text-align: left; }
  .top-total span { align-self: end; }
  .top-total strong { grid-column: 2; grid-row: 1 / span 2; align-self: center; margin: 0; font-size: 22px; text-align: right; }
  .top-total small { align-self: start; }
  .topbar-add { display: none; }
  .mobile-tabbar { position: fixed; z-index: 20; right: 10px; bottom: calc(9px + env(safe-area-inset-bottom)); left: 10px; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); align-items: center; gap: 2px; padding: 7px 4px; border: 1px solid rgba(182,196,190,.9); border-radius: 20px; background: rgba(255,255,255,.96); box-shadow: 0 15px 45px rgba(22,49,42,.2); backdrop-filter: blur(15px); }
  .mobile-tabbar a { display: grid; justify-items: center; gap: 2px; padding: 5px 1px; color: #5c6a64; border-radius: 13px; font-size: 20px; line-height: 1; }
  .mobile-tabbar a small { font-size: 9px; font-weight: 800; letter-spacing: .01em; }
  .mobile-tabbar a.active { color: var(--green); background: #edf4ef; }
  .mobile-tabbar .mobile-add { position: relative; top: -17px; width: 51px; height: 51px; margin: 0 auto -17px; padding: 0; border: 4px solid var(--paper); border-radius: 50%; background: var(--green); color: #fff; box-shadow: 0 8px 18px rgba(43,91,86,.3); }
  .mobile-tabbar .mobile-add span { font-size: 26px; }
  .mobile-tabbar .mobile-add small { position: absolute; top: 50px; color: #53615c; white-space: nowrap; }
  .intro-panel { display: block; padding: 19px; }
  .intro-panel .button { margin-top: 15px; }
  .items-list-header { align-items: flex-start; padding-bottom: 14px; }
  .items-list-header h2 { font-size: 23px; }
  .items-list-header p:not(.eyebrow) { max-width: 290px; font-size: 13px; }
  .mobile-list-add { display: none; }
  .status-chips { margin: 0 -14px 11px; padding: 0 14px 4px; }
  .status-chips a { padding: 8px 12px; font-size: 12px; }
  .filter-panel { margin-bottom: 14px; padding: 12px 13px; border-radius: 13px; }
  .filter-form { gap: 10px; }
  .item-grid { gap: 11px; }
  .item-card { display: grid; grid-template-columns: 105px minmax(0, 1fr); min-height: 126px; border-radius: 15px; }
  .item-card-link { display: contents; }
  .item-image { grid-row: 1; aspect-ratio: auto; min-height: 126px; }
  .item-image .badge { top: 7px; right: 7px; padding: 3px 5px; font-size: 9px; }
  .item-card-body { display: flex; flex-direction: column; min-width: 0; padding: 12px 12px 10px; }
  .item-card-title { gap: 6px; }
  .item-card-title h2 { display: -webkit-box; overflow: hidden; font-size: 15px; line-height: 1.2; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
  .priority-label { padding: 2px 5px; font-size: 9px; }
  .item-meta { min-height: 0; margin: 5px 0 7px; font-size: 11px; }
  .item-card-tags { margin: 0 0 7px; }
  .item-card-tags span { max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .item-card-bottom { margin-top: auto; }
  .item-card-bottom strong { font-size: 16px; }
  .item-card-bottom span { font-size: 10px; }
  .item-card-actions { grid-column: 1 / -1; }
  .item-product-link, .quick-action button { min-height: 42px; padding: 9px; font-size: 12px; }
  .quick-action { grid-column: auto; border-top: 0; }
  .compact-product-link { margin-top: 4px; }
  .quick-entry-intro { align-items: flex-start; padding-bottom: 16px; }
  .quick-entry-icon { width: 41px; height: 41px; font-size: 23px; }
  .quick-entry-intro h2 { font-size: 23px; }
  .quick-entry-intro p:not(.eyebrow) { font-size: 13px; }
  .quick-entry-form { gap: 17px; padding: 18px 15px; border-radius: 16px; }
  .quick-step { grid-template-columns: 27px minmax(0, 1fr); gap: 9px; }
  .quick-step > span { width: 27px; height: 27px; font-size: 12px; }
  .quick-fields.two, .quick-fields.three { grid-template-columns: 1fr; }
  .quick-more { margin-left: 36px; }
  .quick-entry-actions { flex-direction: column-reverse; }
  .quick-entry-actions .button { width: 100%; min-height: 47px; }
  .full-form-link { margin-bottom: 20px; }
  input, select, textarea { min-height: 45px; padding: 11px 12px; font-size: 16px; }
  textarea { min-height: 104px; }
  input[type="file"] { min-height: auto; font-size: 13px; }
  .panel, .item-form { border-radius: 16px; }
}


/* Händlerübersicht – Version 1.2 */
.store-overview-intro { display: flex; align-items: center; justify-content: space-between; gap: 22px; margin: 2px 0 18px; padding: 22px; border: 1px solid #d9e4dc; border-radius: var(--radius); background: linear-gradient(135deg, #f4f8f3, #f9f4e9); }
.store-overview-intro h2 { margin: 4px 0 7px; color: #37443f; font-size: 25px; letter-spacing: -.04em; }
.store-overview-intro p:not(.eyebrow) { max-width: 620px; margin: 0; color: #65746d; font-size: 14px; }
.store-overview-intro .button { flex: 0 0 auto; }
.store-summary-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin: 0 0 17px; }
.store-summary-strip > div { min-height: 76px; padding: 13px 15px; border: 1px solid var(--line); border-radius: 13px; background: #fff; box-shadow: 0 4px 13px rgba(24,39,35,.035); }
.store-summary-strip span { display: block; color: #718079; font-size: 11px; font-weight: 750; }
.store-summary-strip strong { display: block; margin-top: 5px; color: #31443d; font-size: 20px; letter-spacing: -.035em; }
.store-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.store-card { display: grid; grid-template-columns: 47px minmax(0, 1fr) 15px; align-items: center; gap: 12px; min-height: 142px; padding: 16px; border: 1px solid var(--line); border-radius: 16px; background: var(--surface); box-shadow: 0 6px 20px rgba(24,39,35,.035); transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease; }
.store-card:hover { transform: translateY(-2px); border-color: #bbcec0; box-shadow: 0 14px 30px rgba(24,39,35,.09); }
.store-monogram { display: grid; place-items: center; width: 47px; height: 47px; align-self: start; border-radius: 15px; background: linear-gradient(145deg, #e2ede5, #f6ecdc); color: var(--green); font-size: 19px; font-weight: 900; }
.store-card-main { min-width: 0; }
.store-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.store-card-top strong { overflow: hidden; color: #33443d; font-size: 16px; line-height: 1.2; text-overflow: ellipsis; white-space: nowrap; }
.store-card-top > span { flex: 0 0 auto; color: #7b8782; font-size: 10px; font-weight: 750; }
.store-card-money { display: flex; align-items: baseline; justify-content: space-between; gap: 9px; margin: 16px 0 12px; }
.store-card-money small { color: #76827c; font-size: 11px; }
.store-card-money b { color: var(--green); font-size: 18px; letter-spacing: -.03em; }
.store-card-statuses { display: flex; flex-wrap: wrap; gap: 5px; }
.store-card-statuses span { padding: 3px 6px; border-radius: 7px; background: #f2f4f1; color: #718079; font-size: 10px; font-weight: 700; }
.store-arrow { color: #86a096; font-size: 28px; line-height: 1; }

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

@media (max-width: 650px) {
  .mobile-tabbar { grid-template-columns: repeat(5, minmax(0, 1fr)); right: 6px; left: 6px; }
  .mobile-tabbar a { font-size: 18px; }
  .mobile-tabbar a small { font-size: 8px; }
  .mobile-tabbar .mobile-add { width: 49px; height: 49px; top: -16px; margin-bottom: -16px; }
  .mobile-tabbar .mobile-add small { top: 49px; }
  .store-overview-intro { display: block; padding: 18px; border-radius: 16px; }
  .store-overview-intro h2 { font-size: 22px; }
  .store-overview-intro .button { width: 100%; margin-top: 16px; }
  .store-summary-strip { gap: 7px; margin-bottom: 13px; }
  .store-summary-strip > div { min-height: 69px; padding: 11px 10px; border-radius: 12px; }
  .store-summary-strip span { font-size: 9px; }
  .store-summary-strip strong { margin-top: 4px; font-size: 16px; }
  .store-grid { grid-template-columns: 1fr; gap: 10px; }
  .store-card { grid-template-columns: 43px minmax(0, 1fr) 13px; min-height: 118px; gap: 10px; padding: 13px; border-radius: 15px; }
  .store-monogram { width: 43px; height: 43px; border-radius: 13px; font-size: 17px; }
  .store-card-top strong { font-size: 15px; }
  .store-card-money { margin: 12px 0 9px; }
  .store-card-money b { font-size: 17px; }
  .store-arrow { font-size: 24px; }
}


/* Globale Gesamtsumme – Version 1.4 */
@media (max-width: 380px) {
  .top-total strong { font-size: 20px; }
  .top-total span, .top-total small { font-size: 9px; }
}
