:root {
    --color-primary: #2D5A3D;
    --color-primary-light: #3A7450;
    --color-primary-dark: #1E3D29;
    --color-accent: #D4893F;
    --color-accent-light: #E8A85C;
    --color-success: #2D8B4E;
    --color-danger: #C0392B;
    --color-bg: #F5F0EB;
    --color-bg-card: #FFFFFF;
    --color-bg-dark: #1A1A1A;
    --color-text: #2C2C2C;
    --color-text-light: #6B6B6B;
    --color-text-on-dark: #F5F0EB;
    --color-border: #D9D0C7;
    --radius: 12px;
    --shadow: 0 2px 12px rgba(0,0,0,0.08);
    --shadow-hover: 0 4px 20px rgba(0,0,0,0.12);
    --font-heading: 'Playfair Display', Georgia, serif;
    --font-body: 'DM Sans', -apple-system, sans-serif;
}
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family: var(--font-body); color: var(--color-text); background: var(--color-bg); line-height:1.6; }

.header { background: var(--color-bg-dark); color: var(--color-text-on-dark); padding:1.25rem 2rem; }
.header-inner { max-width:1200px; margin:0 auto; }
.logo { font-family: var(--font-heading); font-size:1.6rem; font-weight:700; }
.header-subtitle { color: var(--color-accent); font-size:0.9rem; margin-top:0.2rem; }

.steps-nav { background: var(--color-bg-card); border-bottom:1px solid var(--color-border); padding:0.6rem 1rem; position:sticky; top:0; z-index:100; box-shadow: var(--shadow); overflow-x:auto; }
.steps-inner { max-width:1000px; margin:0 auto; display:flex; align-items:center; min-width:max-content; }
.step-btn { display:flex; align-items:center; gap:0.3rem; padding:0.35rem 0.6rem; border:none; background:transparent; cursor:pointer; border-radius:8px; transition:all 0.3s; font-family:var(--font-body); font-size:0.78rem; color:var(--color-text-light); white-space:nowrap; }
.step-btn:hover { background: var(--color-bg); }
.step-btn.active { background: var(--color-primary); color:white; }
.step-btn.completed { background: var(--color-primary-light); color:white; opacity:0.8; }
.step-number { display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; border-radius:50%; background:var(--color-border); font-weight:600; font-size:0.72rem; color:var(--color-text); }
.step-btn.active .step-number, .step-btn.completed .step-number { background:rgba(255,255,255,0.25); color:white; }
.step-line { flex:1; height:2px; background:var(--color-border); min-width:10px; }

.main-content { max-width:1200px; margin:1.5rem auto; padding:0 1.5rem; }
.step-panel { display:none; }
.step-panel.active { display:block; animation:fadeIn 0.35s; }
@keyframes fadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.panel-header { margin-bottom:1.5rem; }
.panel-header h2 { font-family:var(--font-heading); font-size:1.6rem; color:var(--color-primary-dark); margin-bottom:0.35rem; }
.panel-header p { color:var(--color-text-light); font-size:0.92rem; }

.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.form-group { display:flex; flex-direction:column; gap:0.4rem; }
.form-group.full-width { grid-column:1/-1; }
.form-group label { font-weight:600; font-size:0.85rem; }
.form-group input, .form-group textarea, .form-group select { padding:0.7rem 0.9rem; border:2px solid var(--color-border); border-radius:8px; font-family:var(--font-body); font-size:0.92rem; background:var(--color-bg-card); transition:border-color 0.3s; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline:none; border-color:var(--color-primary); }

.btn { padding:0.7rem 1.5rem; border:none; border-radius:8px; font-family:var(--font-body); font-size:0.92rem; font-weight:600; cursor:pointer; transition:all 0.3s; }
.btn-primary { background:var(--color-primary); color:white; }
.btn-primary:hover { background:var(--color-primary-dark); transform:translateY(-1px); box-shadow:var(--shadow-hover); }
.btn-secondary { background:transparent; color:var(--color-text); border:2px solid var(--color-border); }
.btn-secondary:hover { border-color:var(--color-primary); color:var(--color-primary); }
.btn-success { background:var(--color-success); color:white; font-size:1rem; padding:0.9rem 1.8rem; }
.btn-success:hover { background:#24743F; }
.btn-small { padding:0.35rem 0.75rem; font-size:0.78rem; }
.btn-add { background:var(--color-accent); color:white; }
.btn-remove { background:var(--color-danger); color:white; }
.step-navigation { display:flex; justify-content:space-between; align-items:center; margin-top:2rem; padding-top:1.25rem; border-top:1px solid var(--color-border); }
.empty-hint { color:var(--color-text-light); font-style:italic; font-size:0.88rem; }

/* FORM CHOICE ROW */
.form-choice-row { display:flex; gap:0.5rem; margin-bottom:1rem; }
.form-choice-btn { flex:1; padding:0.7rem 0.5rem; border-radius:12px; border:2px solid var(--color-border); background:white; cursor:pointer; text-align:center; transition:all 0.2s; font-family:var(--font-body); }
.form-choice-btn:hover { border-color:var(--color-primary-light); box-shadow:var(--shadow); }
.form-choice-btn.selected { border-color:var(--color-primary); background:var(--color-primary); color:white; }
.form-choice-icon { display:block; font-size:1.3rem; margin-bottom:0.1rem; }
.form-choice-label { display:block; font-weight:700; font-size:0.88rem; }
.form-choice-desc { display:block; font-size:0.65rem; opacity:0.7; }

/* DIMENSION ROW */
.dim-row { display:flex; gap:0.75rem; margin-bottom:1rem; flex-wrap:wrap; align-items:flex-end; }
.dim-group label { font-size:0.78rem; font-weight:600; display:block; margin-bottom:0.2rem; }
.dim-group input { padding:0.4rem; border:2px solid var(--color-border); border-radius:6px; width:130px; font-size:0.9rem; font-family:var(--font-body); background:white; }
.dim-group input:focus { outline:none; border-color:var(--color-primary); }
.dim-tip { font-size:0.75rem; color:var(--color-text-light); padding:0.4rem 0.7rem; background:var(--color-bg); border-radius:6px; line-height:1.6; }
.dim-tip code { background:#e8e0d8; padding:0 4px; border-radius:3px; }

/* EDITOR LAYOUT */
.editor-layout { display:flex; gap:1.25rem; align-items:flex-start; }
.catalog-panel { width:230px; flex-shrink:0; }
.catalog-panel h3 { font-family:var(--font-heading); font-size:1rem; color:var(--color-primary-dark); margin-bottom:0.5rem; }
.grundriss-panel { flex:1; min-width:0; }
.grundriss-svg-area { background:white; border:2px solid var(--color-border); border-radius:12px; padding:1rem; overflow:auto; margin-bottom:1rem; }
.leg-summaries { display:flex; gap:0.75rem; flex-wrap:wrap; margin-bottom:1rem; }
.editor-empty { text-align:center; padding:3rem; color:#999; background:white; border-radius:12px; border:2px dashed var(--color-border); margin-top:1rem; }

/* MODULE ACCORDION */
.module-accordion { max-height:550px; overflow-y:auto; border:1px solid var(--color-border); border-radius:10px; background:white; }
.kat-header { padding:0.55rem 0.7rem; cursor:pointer; display:flex; justify-content:space-between; background:transparent; border-bottom:1px solid #eee; font-weight:600; font-size:0.8rem; user-select:none; }
.kat-header.open { background:rgba(45,90,61,0.06); color:var(--color-primary-dark); }
.kat-items { padding:0.3rem; }
.drag-module { padding:0.45rem 0.55rem; margin:0.2rem 0; background:#FAFAFA; border:1.5px solid #e8e0d8; border-radius:6px; cursor:grab; font-size:0.78rem; transition:all 0.15s; }
.drag-module:hover { background:#f0ede8; }
.drag-module-name { font-weight:600; }
.drag-module-info { color:var(--color-text-light); font-size:0.68rem; }
.drag-module-content { display:flex; align-items:center; gap:0.5rem; }
.drag-module-img { width:48px; height:48px; object-fit:cover; border-radius:4px; border:1px solid #e8e0d8; flex-shrink:0; }

/* KI Visualisierung */
.ki-loading { text-align:center; padding:3rem 1rem; }
.ki-loading p { color:var(--color-text); margin-top:1rem; font-size:0.95rem; }
.ki-loading-sub { color:var(--color-text-light) !important; font-size:0.82rem !important; }
.ki-error { text-align:center; padding:2rem; background:#FFF5F5; border:1px solid #E8A0A0; border-radius:8px; }
.ki-error p { margin:0.5rem 0; }
.ki-error .btn { margin-top:1rem; }
#ki-bild { width:100%; max-width:800px; border-radius:8px; box-shadow:0 4px 16px rgba(0,0,0,0.15); display:block; margin:0 auto; }
.ki-result { text-align:center; }
.ki-result-info { margin:1.5rem 0 1rem; }
.ki-result-info p { margin:0.3rem 0; color:var(--color-text-light); }
.ki-result-info strong { color:var(--color-text); }
.ki-result-actions { display:flex; gap:0.75rem; justify-content:center; margin-top:1rem; }

/* LEG SUMMARY CARD */
.leg-card { flex:1; min-width:170px; padding:0.65rem; background:white; border:1.5px solid var(--color-border); border-radius:8px; }
.leg-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:0.25rem; }
.leg-card-title { font-weight:700; font-size:0.82rem; color:var(--color-primary-dark); }
.leg-bar { height:6px; background:#e8e0d8; border-radius:3px; overflow:hidden; margin-bottom:0.25rem; }
.leg-bar-fill { height:100%; border-radius:3px; transition:width 0.3s; }
.leg-status { font-size:0.72rem; margin-bottom:0.3rem; }
.leg-module-item { font-size:0.72rem; display:flex; justify-content:space-between; align-items:center; padding:0.2rem 0.3rem; margin:0.1rem 0; background:#FAFAFA; border-radius:4px; }
.leg-remove-btn { background:var(--color-danger); color:white; border:none; border-radius:3px; width:18px; height:18px; cursor:pointer; font-size:0.7rem; font-weight:700; display:flex; align-items:center; justify-content:center; }
.subtract-btn { padding:0.15rem 0.4rem; font-size:0.65rem; border-radius:4px; border:1px solid var(--color-border); background:var(--color-bg); cursor:pointer; font-family:var(--font-body); color:var(--color-text-light); }

/* EDITOR SUMMARY BAR */
.editor-summary-bar { display:flex; justify-content:space-between; align-items:center; padding:0.75rem 1rem; background:var(--color-primary-dark); color:white; border-radius:10px; font-size:0.88rem; }
.editor-summary-bar .price { font-weight:700; font-size:1rem; }

/* MATERIAL ZONES */
.material-zone { background:var(--color-bg-card); border:2px solid var(--color-border); border-radius:var(--radius); padding:1.25rem; margin-bottom:1rem; }
.zone-header { margin-bottom:0.75rem; }
.zone-header h3 { font-family:var(--font-heading); font-size:1.1rem; color:var(--color-primary-dark); margin-bottom:0.15rem; }
.zone-header p { font-size:0.82rem; color:var(--color-text-light); }
.material-swatches { display:grid; grid-template-columns:repeat(auto-fill, minmax(145px, 1fr)); gap:0.6rem; }
.material-swatch { border:3px solid var(--color-border); border-radius:8px; padding:0.6rem; cursor:pointer; transition:all 0.3s; text-align:center; }
.material-swatch:hover { border-color:var(--color-primary-light); transform:translateY(-1px); }
.material-swatch.selected { border-color:var(--color-primary); box-shadow:0 0 0 2px var(--color-primary); }
.swatch-color { width:100%; height:36px; border-radius:4px; margin-bottom:0.4rem; border:1px solid rgba(0,0,0,0.1); }
.swatch-name { font-size:0.76rem; font-weight:600; margin-bottom:0.1rem; }
.swatch-price { font-size:0.72rem; color:var(--color-text-light); }
.front-module-row { display:flex; align-items:center; gap:0.5rem; padding:0.6rem 0.75rem; background:var(--color-bg); border-radius:8px; margin-bottom:0.4rem; flex-wrap:wrap; }
.front-module-label { font-weight:600; font-size:0.85rem; min-width:180px; }
.front-select { flex:1; min-width:140px; padding:0.5rem; border:2px solid var(--color-border); border-radius:6px; font-family:var(--font-body); font-size:0.85rem; }

/* ZUBEHOER */
.zubehoer-card { background:var(--color-bg-card); border:2px solid var(--color-border); border-radius:var(--radius); padding:1rem; margin-bottom:0.6rem; display:flex; justify-content:space-between; align-items:center; }
.zubehoer-card.added { border-color:var(--color-primary); background:rgba(45,90,61,0.04); }
.zubehoer-name { font-weight:600; font-size:0.9rem; margin-bottom:0.15rem; }
.zubehoer-desc { font-size:0.8rem; color:var(--color-text-light); }
.zubehoer-right { display:flex; align-items:center; gap:0.75rem; }
.zubehoer-price { font-weight:700; color:var(--color-primary-dark); white-space:nowrap; }

/* SUMMARY */
.summary-card { background:var(--color-bg-card); border:2px solid var(--color-border); border-radius:var(--radius); padding:1.25rem; margin-bottom:1rem; }
.summary-card h3 { font-family:var(--font-heading); color:var(--color-primary-dark); margin-bottom:0.75rem; padding-bottom:0.4rem; border-bottom:1px solid var(--color-border); font-size:1.05rem; }
.summary-row { display:flex; justify-content:space-between; padding:0.35rem 0; font-size:0.88rem; }
.price-card { border-color:var(--color-primary); }
.total-price { display:flex; justify-content:space-between; margin-top:0.75rem; padding-top:0.75rem; border-top:2px solid var(--color-primary); font-size:1.3rem; font-weight:700; color:var(--color-primary-dark); }

.visualization-area { background:var(--color-bg-card); border:2px solid var(--color-border); border-radius:var(--radius); padding:2rem; min-height:400px; display:flex; align-items:center; justify-content:center; flex-direction:column; }
#ki-bild { max-width:100%; border-radius:var(--radius); box-shadow:var(--shadow-hover); }
.loading { text-align:center; color:var(--color-text-light); padding:2rem; }
.spinner { width:48px; height:48px; border:4px solid var(--color-border); border-top-color:var(--color-primary); border-radius:50%; animation:spin 0.8s linear infinite; margin:0 auto 1rem; }
@keyframes spin { to { transform:rotate(360deg); } }
.footer { background:var(--color-bg-dark); color:var(--color-text-light); text-align:center; padding:1.25rem; margin-top:2.5rem; font-size:0.82rem; }

@media (max-width:768px) {
    .form-grid { grid-template-columns:1fr; }
    .form-choice-row { flex-wrap:wrap; }
    .form-choice-btn { min-width:calc(50% - 0.5rem); }
    .editor-layout { flex-direction:column; }
    .catalog-panel { width:100%; }
    .material-swatches { grid-template-columns:repeat(auto-fill, minmax(110px,1fr)); }
    .front-module-row { flex-direction:column; align-items:stretch; }
    .step-label { display:none; }
}

/* =============================================
   SVG VISUALIZATION - Step 6
   ============================================= */

.viz-container {
    background: var(--color-bg-card);
    border: 2px solid var(--color-border);
    border-radius: var(--radius);
    margin-bottom: 1.5rem;
    overflow: hidden;
}

.viz-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--color-border);
    background: rgba(45, 90, 61, 0.03);
}

.viz-header h3 {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    color: var(--color-primary-dark);
    margin-bottom: 0.15rem;
}

.viz-header p {
    font-size: 0.82rem;
    color: var(--color-text-light);
}

.svg-visualization {
    padding: 1.25rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
    overflow-x: auto;
}

.viz-section {
    flex: 1;
    min-width: 300px;
}

.viz-card {
    background: white;
    border: 1px solid #eee;
    border-radius: 8px;
    padding: 0.75rem;
    overflow-x: auto;
    box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}

.viz-card svg {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
}

#ki-bild-container {
    text-align: center;
    padding: 1rem;
}

#ki-bild {
    max-width: 100%;
    border-radius: var(--radius);
    box-shadow: var(--shadow-hover);
}

.ki-actions {
    margin-top: 1rem;
    display: flex;
    gap: 0.75rem;
    justify-content: center;
}

@media (max-width: 768px) {
    .svg-visualization { flex-direction: column; }
    .viz-section { min-width: auto; }
}

.viz-section-full {
    flex: 0 0 100%;
    min-width: 100%;
}

.viz-card {
}
.svg-visualization {
}
.viz-container {
}

.viz-section-full .viz-card svg {
    max-height: 600px;
    max-width: 100%;
    margin: 0 auto;
}

/* Override rows */
.override-row { padding:0.5rem 0.75rem; background:var(--color-bg); border-radius:8px; margin-bottom:0.4rem; }
.override-row.has-override { border-left:3px solid var(--color-primary); }
.override-label { font-size:0.85rem; margin-bottom:0.3rem; }
.override-selects { display:flex; gap:0.5rem; flex-wrap:wrap; }
.override-field { display:flex; align-items:center; gap:0.3rem; flex:1; min-width:200px; }
.override-field label { font-size:0.78rem; font-weight:600; color:var(--color-text-light); white-space:nowrap; }
.override-field select { flex:1; padding:0.35rem; border:2px solid var(--color-border); border-radius:6px; font-size:0.82rem; font-family:var(--font-body); }
.btn-outline { background:transparent; border:2px solid var(--color-border); color:var(--color-text); padding:0.4rem 1rem; border-radius:6px; cursor:pointer; }
.btn-outline:hover { border-color:var(--color-primary); color:var(--color-primary); }

/* Drag reorder styles */
.leg-module-item[draggable] { transition: background 0.15s, transform 0.15s; user-select: none; display: flex; align-items: center; gap: 0.3rem; }
.leg-module-item .drag-handle { color: #bbb; font-size: 0.9rem; cursor: grab; padding: 0 0.2rem; }
.leg-module-item .drag-handle:hover { color: #888; }
.leg-module-item.dragging { opacity: 0.4; background: #f0f0f0; }
.leg-module-item.drag-over-top { border-top: 2px solid var(--color-primary) !important; }
.leg-module-item.drag-over-bottom { border-bottom: 2px solid var(--color-primary) !important; }
.leg-mod-name { flex: 1; }

/* Save/Load bar */
.save-load-bar { display:flex; align-items:center; gap:0.5rem; padding:0.5rem 1rem; background:var(--color-bg-card); border-bottom:1px solid var(--color-border); }
.btn-save { background:#2D8B4E; color:white; border:none; padding:0.4rem 1rem; border-radius:6px; cursor:pointer; font-size:0.85rem; font-weight:600; }
.btn-save:hover { background:#24703F; }
.btn-load { background:#4A6FA5; color:white; border:none; padding:0.4rem 1rem; border-radius:6px; cursor:pointer; font-size:0.85rem; font-weight:600; }
.btn-load:hover { background:#3B5A8A; }
.konfig-code-display { font-family:monospace; font-size:0.9rem; font-weight:700; color:var(--color-primary); padding:0.3rem 0.6rem; background:rgba(45,139,78,0.1); border-radius:4px; }
/* Modal */
.modal-overlay { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.5); display:flex; align-items:center; justify-content:center; z-index:9999; }
.modal-box { background:white; border-radius:12px; padding:2rem; max-width:420px; width:90%; box-shadow:0 8px 30px rgba(0,0,0,0.2); }
.modal-box h3 { margin-bottom:0.5rem; color:var(--color-primary-dark); }
.modal-box p { font-size:0.9rem; color:var(--color-text-light); margin-bottom:1rem; }
.load-code-input { width:100%; padding:0.8rem; font-size:1.3rem; font-family:monospace; text-align:center; border:3px solid var(--color-border); border-radius:8px; letter-spacing:2px; margin-bottom:1rem; }
.load-code-input:focus { border-color:var(--color-primary); outline:none; }
.modal-buttons { display:flex; gap:0.5rem; justify-content:flex-end; }
.load-error { color:#C0392B; font-size:0.85rem; margin-top:0.5rem; min-height:1.2em; }
/* Toast */
.save-toast { position:fixed; top:80px; right:20px; background:#2D8B4E; color:white; padding:1rem 1.5rem; border-radius:10px; font-weight:600; font-size:0.95rem; box-shadow:0 4px 15px rgba(0,0,0,0.2); z-index:9999; animation:slideIn 0.3s ease; }
@keyframes slideIn { from { transform:translateX(100px); opacity:0; } to { transform:translateX(0); opacity:1; } }


/* Start Screen */
.start-screen { max-width:900px; margin:2rem auto; padding:0 1rem; }
.start-hero { text-align:center; margin-bottom:2rem; }
.start-hero h2 { font-size:1.6rem; color:var(--color-primary-dark); margin-bottom:0.3rem; }
.start-hero p { color:var(--color-text-light); font-size:1rem; }
.start-choices { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-bottom:2rem; }
.start-card { background:var(--color-bg-card); border:3px solid var(--color-border); border-radius:16px; padding:2rem; text-align:center; cursor:pointer; transition:all 0.25s; }
.start-card:hover { transform:translateY(-3px); box-shadow:0 8px 25px rgba(0,0,0,0.1); }
.start-card-new:hover { border-color:var(--color-primary); }
.start-card-load:hover { border-color:#4A6FA5; }
.start-card-icon { font-size:2.5rem; margin-bottom:0.5rem; }
.start-card h3 { font-size:1.15rem; margin-bottom:0.3rem; color:var(--color-primary-dark); }
.start-card p { font-size:0.85rem; color:var(--color-text-light); margin:0; }
.start-load-section { background:var(--color-bg-card); border:2px solid var(--color-border); border-radius:16px; padding:1.5rem; animation:fadeIn 0.3s ease; }
@keyframes fadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.start-load-code { text-align:center; margin-bottom:1rem; }
.start-load-code h3 { font-size:1rem; margin-bottom:0.5rem; }
.code-input-row { display:flex; gap:0.5rem; justify-content:center; align-items:center; }
.start-code-input { padding:0.7rem 1rem; font-size:1.3rem; font-family:monospace; text-align:center; border:3px solid var(--color-border); border-radius:10px; letter-spacing:2px; width:200px; text-transform:uppercase; }
.start-code-input:focus { border-color:var(--color-primary); outline:none; }
.start-divider { text-align:center; margin:1.2rem 0; position:relative; }
.start-divider::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:var(--color-border); }
.start-divider span { position:relative; background:var(--color-bg-card); padding:0 1rem; font-size:0.85rem; color:var(--color-text-light); }
.start-kunden-tabelle { max-height:400px; overflow-y:auto; margin-top:0.5rem; }
.konfig-row { display:grid; grid-template-columns:1.5fr 0.8fr 1fr 0.8fr 0.7fr; gap:0.5rem; align-items:center; padding:0.6rem 0.8rem; border-bottom:1px solid #eee; cursor:pointer; transition:background 0.15s; font-size:0.85rem; }
.konfig-row:hover { background:rgba(45,139,78,0.05); }
.konfig-row-header { font-weight:700; font-size:0.78rem; color:var(--color-text-light); text-transform:uppercase; cursor:default; border-bottom:2px solid var(--color-border); }
.konfig-row-header:hover { background:transparent; }
.konfig-row .kunde-name { font-weight:600; color:var(--color-primary-dark); }
.konfig-row .form-type { text-transform:capitalize; }
.konfig-row .code { font-family:monospace; color:var(--color-primary); font-size:0.8rem; }
.konfig-row .datum { color:#999; font-size:0.8rem; }
.konfig-row .preis { font-weight:600; text-align:right; }
@media (max-width:600px) { .start-choices { grid-template-columns:1fr; } .konfig-row { grid-template-columns:1fr 1fr; } }

.btn-back-start { background:transparent; border:2px solid var(--color-border); color:var(--color-text-light); padding:0.3rem 0.6rem; border-radius:6px; cursor:pointer; font-size:1rem; line-height:1; }
.btn-back-start:hover { border-color:var(--color-primary); color:var(--color-primary); }

/* Live-Preis in Save-Bar */
.live-preis {
    font-weight: bold;
    color: #2d5016;
    font-size: 1.1em;
    padding: 6px 16px;
    background: #e8f5e9;
    border-radius: 8px;
    margin-left: 12px;
    white-space: nowrap;
}


/* ============ ZUBEHOER STEP ============ */
.zubehoer-kategorie {
    margin-bottom: 24px;
}
.zubehoer-kategorie h3 {
    font-size: 1.1rem;
    margin-bottom: 12px;
    padding-bottom: 6px;
    border-bottom: 2px solid #5a7a5a;
    color: #333;
}
.zubehoer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
}
.zubehoer-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    transition: all 0.2s;
}
.zubehoer-card:hover {
    border-color: #5a7a5a;
}
.zubehoer-card.zubehoer-active {
    border-color: #5a7a5a;
    background: #f0f5f0;
}
.zubehoer-info {
    flex: 1;
}
.zubehoer-name {
    font-weight: 600;
    font-size: 0.95rem;
    color: #222;
}
.zubehoer-hersteller {
    font-size: 0.8rem;
    color: #888;
    margin-top: 2px;
}
.zubehoer-masse {
    font-size: 0.8rem;
    color: #666;
    margin-top: 2px;
}
.zubehoer-preis {
    font-weight: 700;
    color: #5a7a5a;
    margin-top: 4px;
    font-size: 1rem;
}
.zubehoer-menge {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: 16px;
}
.btn-menge {
    width: 32px;
    height: 32px;
    border: 2px solid #ccc;
    border-radius: 50%;
    background: #fff;
    font-size: 1.1rem;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
    color: #333;
    padding: 0;
    line-height: 1;
}
.btn-menge:hover {
    border-color: #5a7a5a;
    background: #5a7a5a;
    color: #fff;
}
.menge-display {
    font-weight: 700;
    font-size: 1.1rem;
    min-width: 20px;
    text-align: center;
}
.zubehoer-auswahl-box {
    margin-top: 20px;
    padding: 16px;
    background: #f8f5f0;
    border-radius: 8px;
    border: 1px solid #e0d8c8;
}
.zubehoer-auswahl-box h3 {
    margin: 0 0 12px 0;
    font-size: 1rem;
    color: #333;
}
.zubehoer-auswahl-item {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.9rem;
}
.zubehoer-auswahl-total {
    display: flex;
    justify-content: space-between;
    padding-top: 8px;
    margin-top: 8px;
    border-top: 2px solid #5a7a5a;
    font-size: 1rem;
}
/* ============ ENDE ZUBEHOER ============ */

/* Delete Button in Konfig-Liste */
.konfig-row { grid-template-columns: 2fr 1fr 1.5fr 1fr 1fr 40px !important; }
.konfig-row-header { grid-template-columns: 2fr 1fr 1.5fr 1fr 1fr 40px !important; }
.delete-btn { cursor: pointer; font-size: 1.2rem; opacity: 0.5; text-align: center; }
.delete-btn:hover { opacity: 1; color: #C0392B; }
