
:root{
  --bg:#04101f;--bg2:#071a34;--panel:#0b1a35;--panel2:#122544;--line:#4e6a8a;--line2:#2a3f5c;
  --text:#eef3ff;--muted:#c2d0ee;--gold:#ead981;--green:#6ea235;--green2:#94c95d;--red:#8f1717;--red2:#c32a2a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Arial,Helvetica,sans-serif;background:radial-gradient(circle at top, rgba(18,33,74,.72), transparent 35%), linear-gradient(180deg,var(--bg2) 0%, var(--bg) 56%, #020812 100%);color:var(--text);min-height:100vh}
body{cursor:default}
a,button,select,input,textarea,.slot,.lang-btn,.back-btn,.cta,.remove-btn{cursor:pointer}
img{max-width:100%;display:block}
.topbar{position:sticky;top:0;z-index:40;height:78px;background:#020a16;border-bottom:1px solid #2d4b72;display:flex;align-items:center;padding:0 clamp(12px,1.8vw,28px)}
.topbar img{width:clamp(170px,13vw,240px);max-width:none;height:auto}
.page{min-height:calc(100vh - 78px);padding:18px clamp(12px,1.8vw,28px) 24px}
.shell{width:min(1520px, calc(100vw - 32px));max-width:none;margin:0 auto;background:linear-gradient(180deg, rgba(10,30,63,.88), rgba(6,17,40,.96));border:1px solid rgba(74,110,160,.45);border-radius:24px;padding:22px 24px;box-shadow:0 28px 90px rgba(0,0,0,.42), inset 0 0 40px rgba(33,71,126,.14)}
.hero-box{display:grid;place-items:center;min-height:68vh;padding:32px}
.hero-card{width:min(100%,1080px);background:linear-gradient(180deg, rgba(8,24,52,.92), rgba(6,18,40,.96));border:1px solid rgba(64,108,164,.45);border-radius:28px;box-shadow:0 28px 90px rgba(0,0,0,.42), inset 0 0 40px rgba(33,71,126,.18);padding:42px 28px;text-align:center}
.language-card{max-width:820px}
.goldline{letter-spacing:4px;color:var(--gold);font-size:15px;margin-bottom:14px;text-transform:uppercase}
.hero-logo{width:320px;max-width:60vw;margin:0 auto 18px}
.hero-title{font-size:88px;line-height:0.95;margin:0 0 20px;font-weight:800}
.hero-copy{font-size:24px;line-height:1.45;color:#d9e3fb;margin:0 auto 26px;max-width:880px}
.lang-row,.hero-actions,.review-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.lang-btn,.cta,.back-btn{border:1px solid #6e8bb1;border-radius:18px;padding:18px 28px;background:#13294d;color:#fff;font-weight:700;font-size:22px;text-decoration:none;min-width:220px}
.cta.primary{background:linear-gradient(180deg,#a7c063,#879f43);color:#0b1204;border-color:#a0b95d}
.back-btn{min-width:auto;padding:12px 18px;font-size:15px;background:#102441}
.header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.header-row h1{font-size:clamp(40px,3vw,62px);line-height:1;margin:0}
.machine{border-radius:22px;background:linear-gradient(180deg,#3e4651,#242d39);padding:12px;box-shadow: inset 0 0 0 4px #6f7f91, inset 0 0 0 6px #2a394b, 0 15px 40px rgba(0,0,0,.35);}
.machine-red{border-radius:18px;background:linear-gradient(180deg,#b12929,#811515);padding:10px;box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);}
.machine-inner{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:14px;border-radius:14px;background:linear-gradient(180deg,#3a4550,#262f38);padding:12px;box-shadow: inset 0 0 0 3px #607184}
.machine-banner{grid-column:1 / -1;border-radius:10px;background:linear-gradient(90deg,#111722,#283544,#111722);padding:16px 22px;font-size:clamp(28px,3vw,58px);font-weight:800;color:white;border:2px solid #6f8094}
.grid{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}
.slot{background:linear-gradient(180deg,#334557,#1e2b39);border-radius:14px;padding:10px;border:2px solid #6e8093;box-shadow:inset 0 0 0 2px #32455d;transition:transform .15s ease,border-color .15s ease, box-shadow .15s ease;display:flex;flex-direction:column;min-width:0}
.slot:hover,.slot:focus-visible{transform:translateY(-1px);border-color:#b4e74f;box-shadow:inset 0 0 0 2px #32455d,0 0 0 2px rgba(180,231,79,.18)}
.slot.selected{border-color:#b4e74f;box-shadow:inset 0 0 0 2px #32455d,0 0 0 3px rgba(180,231,79,.25)}
.slot-top{position:relative;height:214px;border-radius:12px;background:linear-gradient(180deg,#41566a,#263548);border:2px solid #5f7288;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px}
.badge{position:absolute;left:10px;top:10px;border-radius:12px;background:#101823;color:#f4d870;padding:10px 12px;font-weight:800;font-size:17px;border:1px solid #3a4758}
.img-placeholder{width:90px;height:90px;border-radius:16px;background:#dfddd0;display:grid;place-items:center;font-size:12px;text-align:center;padding:8px;color:#5e6570;box-shadow:inset 0 0 0 2px rgba(0,0,0,.08)}
.spirals{display:flex;gap:10px;color:#aab2bd;font-size:56px;line-height:0.65}
.price{margin-top:10px;border-radius:10px;background:linear-gradient(180deg,#111822,#090d12);border:1px solid #586878;padding:8px 10px;text-align:center;font-size:26px;font-weight:800;color:#f4d870}
.namebar{min-height:54px;max-height:54px;overflow:hidden;text-align:center;line-height:1.15;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;border-radius:10px;background:linear-gradient(180deg,#648825,#486517);border:1px solid #84aa41;padding:8px 10px;font-size:17px;font-weight:700}
.select-light{margin-top:10px;height:44px;border-radius:10px;background:linear-gradient(180deg,#081019,#06090d);border:1px solid #586878;display:grid;place-items:center}
.namebar-bundle{display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:8px;padding:6px 8px}
.namebar-bundle .namebar-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-align:left;justify-self:start;line-height:1.15;word-break:break-word}
.select-light-bundle{display:flex;align-items:center;justify-content:center;padding:6px 8px}
.slot-mini-btn{border:none;border-radius:11px;background:linear-gradient(180deg,#102240,#0a1628);color:#fff;border:1px solid #7b96b8;min-width:34px;height:32px;padding:0 10px;font-size:13px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;box-shadow:0 4px 10px rgba(0,0,0,.18)}
.slot-info-btn{padding:0;min-width:36px;width:36px}
.slot-info-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:#173a74;color:#fff;font-size:12px;font-weight:800}
.slot-bundle-select{width:100%;height:32px;border-radius:10px;background:#0b1729;color:#fff;border:1px solid #7b96b8;padding:0 34px 0 12px;font-size:13px;font-weight:700;appearance:none;background-image:linear-gradient(45deg,transparent 50%, #d9e3fb 50%),linear-gradient(135deg,#d9e3fb 50%, transparent 50%);background-position:calc(100% - 16px) 12px, calc(100% - 10px) 12px;background-size:6px 6px, 6px 6px;background-repeat:no-repeat}
.slot-bundle-select:focus{outline:none;border-color:#b4e74f;box-shadow:0 0 0 2px rgba(180,231,79,.18)}
.cart-subnote{color:#d8e7ff;font-size:12px;margin:2px 0 4px}
.modal-backdrop{position:fixed;inset:0;background:rgba(2,8,18,.7);display:grid;place-items:center;padding:20px;z-index:120}
.modal-card{width:min(720px,100%);background:linear-gradient(180deg, rgba(10,30,63,.96), rgba(6,17,40,.98));border:1px solid rgba(74,110,160,.55);border-radius:20px;padding:18px 18px 20px;box-shadow:0 24px 80px rgba(0,0,0,.45)}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.modal-head h3{margin:0;font-size:28px}
.modal-title{font-size:24px;font-weight:800;margin-bottom:12px}
.modal-content{background:#08172d;border:1px solid #4b6a90;border-radius:14px;padding:16px;line-height:1.55;white-space:normal}
.bundle-only.is-hidden{display:none}

.select-light span{width:70px;height:14px;border-radius:999px;background:#d4f57a;box-shadow:0 0 18px rgba(212,245,122,.7)}
.side{display:flex;flex-direction:column;gap:12px;align-self:stretch}
.led{border-radius:12px;background:#05090e;border:2px solid #5f7288;padding:18px 16px;color:#e9f08d}
.led .line{display:flex;justify-content:space-between;align-items:flex-end;gap:8px}
.led .currency{font-size:22px;font-weight:700}
.led .amount{font-size:64px;line-height:1;font-weight:800}
.led .small{font-size:18px;font-weight:700}
.cartbox{border-radius:12px;background:rgba(255,255,255,.04);border:1px solid #5f7288;padding:12px;display:flex;flex-direction:column;gap:10px;min-height:220px;flex:0 0 auto}
.cartbox-compact{gap:12px}
.cartbox h3{margin:0;color:#e7d266;font-size:16px;letter-spacing:2px;text-transform:uppercase}
.cart-list{display:flex;flex-direction:column;gap:8px;padding-right:4px;overflow:visible}
.cart-item{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:start;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:8px}
.cart-item:last-child{border-bottom:none}
.remove-btn{width:28px;height:28px;border-radius:50%;background:#182637;border:1px solid #71849b;color:#fff;font-weight:700}
.order-btn{border:none;border-radius:12px;padding:18px 16px;background:linear-gradient(180deg,#6da238,#5b8f2d);color:#fff;font-size:18px;font-weight:800}
.order-btn-inline{margin-top:6px}
.dots{display:flex;gap:10px;padding:4px 0 0 6px}
.dot{width:20px;height:20px;border-radius:50%;background:#cfaa49;box-shadow:0 0 12px rgba(207,170,73,.45)}
.dot.green{background:#d7fb77;box-shadow:0 0 14px rgba(215,251,119,.8)}
.form-layout,.review-layout{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:18px}
.card{background:linear-gradient(180deg, rgba(10,30,63,.88), rgba(6,17,40,.96));border:1px solid rgba(74,110,160,.45);border-radius:18px;padding:18px}
.card h2,.card h3{margin:0 0 12px}
.radio-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.radio-card{display:flex;gap:10px;align-items:flex-start;padding:12px;border:1px solid #4b6a90;border-radius:14px;background:#0c1930}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.field label{font-weight:700}
input,select,textarea{width:100%;background:#08172d;color:#fff;border:1px solid #4b6a90;border-radius:12px;padding:14px 14px;font-size:16px}
textarea{min-height:120px;resize:vertical}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.summary-line{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.review-box{display:flex;flex-direction:column;gap:10px}
.review-actions{justify-content:flex-start}
.center{display:grid;place-items:center}
.confirm-card{max-width:960px;margin:0 auto;text-align:center}
.note{color:var(--muted)}

@media (max-width:1400px){.shell{width:min(1360px, calc(100vw - 28px));padding:20px 20px}.machine-banner{font-size:44px}.header-row h1{font-size:48px}.form-layout,.review-layout{grid-template-columns:1fr 360px}}
@media (max-width:1100px){.machine-inner{grid-template-columns:1fr}.side{order:2}.machine-banner{font-size:36px}.header-row h1{font-size:40px}.hero-title{font-size:66px}}
@media (max-width:900px){.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar img{width:170px}.form-layout,.review-layout{grid-template-columns:1fr}.hero-title{font-size:52px}.hero-copy{font-size:21px}.shell{padding:12px}.machine-inner{padding:10px}.slot{padding:8px}.slot-top{height:170px;gap:10px}.badge{padding:8px 10px;font-size:15px}.img-placeholder{width:76px;height:76px;font-size:11px}.spirals{font-size:44px;gap:8px}.price{font-size:22px;padding:7px 8px}.namebar{min-height:54px;max-height:54px;overflow:hidden;text-align:center;line-height:1.15;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;padding:8px}.select-light{height:38px}.select-light span{width:56px;height:12px}}
@media (max-width:700px){.machine-banner{font-size:24px;padding:14px}.header-row h1{font-size:34px}.hero-card{padding:28px 18px}.hero-title{font-size:40px}.hero-copy{font-size:18px}.lang-btn,.cta{min-width:180px;font-size:18px;padding:14px 18px}.two-col,.radio-grid{grid-template-columns:1fr}.topbar{height:68px;padding:0 10px}.topbar img{width:150px}.page{padding:12px}.shell{width:min(100%, calc(100vw - 24px));padding:16px 14px;border-radius:22px}.cartbox{min-height:0}}
@media (max-width:520px){.header-row h1{font-size:28px}.grid{gap:10px}.slot-top{height:148px}.img-placeholder{width:68px;height:68px}.spirals{font-size:38px}.price{font-size:18px}.namebar{min-height:54px;max-height:54px;overflow:hidden;text-align:center;line-height:1.15;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;padding:7px 6px}.select-light{height:34px}.select-light span{width:48px;height:10px}.slot-mini-btn{min-width:28px;height:26px;font-size:11px;padding:0 8px}.slot-option-btn{min-width:54px}}
@media (orientation:landscape) and (max-width:900px){.grid{grid-template-columns:repeat(3,minmax(0,1fr))}.slot-top{height:150px}.price{font-size:18px}.namebar{min-height:54px;max-height:54px;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center;line-height:1.15;padding:8px 10px;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px}}
body{overflow-x:hidden}
button:disabled{opacity:.7;cursor:not-allowed}
hr{border:none;border-top:1px solid rgba(255,255,255,.08);margin:16px 0}
.alert{border-radius:16px;padding:14px 16px;margin:0 0 16px}
.alert.error{background:rgba(143,23,23,.18);border:1px solid rgba(195,42,42,.55);color:#ffdede}
.alert ul{margin:8px 0 0 18px;padding:0}
.confirm-meta{max-width:720px;margin:18px auto 0;text-align:left}


.radio-card{display:grid;grid-template-columns:28px minmax(0,1fr);align-items:start;column-gap:12px;row-gap:4px;min-width:0}
.radio-card input{margin:6px 0 0 0;width:28px;height:28px;accent-color:#1492ff}
.radio-card > div{min-width:0}
.radio-card strong,.radio-card .note{display:block;overflow-wrap:anywhere}
.order-top-actions{display:flex;justify-content:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.admin-grid{display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px}
.admin-login-card{max-width:520px;margin:0 auto}
.admin-table{width:100%;border-collapse:collapse;font-size:15px}
.admin-table th,.admin-table td{padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;vertical-align:top}
.admin-table th{color:#d7e6ff;font-size:13px;text-transform:uppercase;letter-spacing:.06em}
.admin-table tr:hover td{background:rgba(255,255,255,.03)}
.admin-chip{display:inline-block;border:1px solid #5d789a;background:#11233f;color:#fff;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}
.admin-chip.new{background:#243d63}
.admin-chip.in_progress{background:#63511f}
.admin-chip.shipped{background:#1f5d63}
.admin-chip.done{background:#2f5a2d}
.admin-chip.archived{background:#3b4050;color:#cbd5e1}
.admin-chip.payment_pending{background:#5f4b18;color:#ffe28a;border-color:#d1a94a}
.admin-chip.payment_cancelled{background:#4c2630;color:#ffc7d0;border-color:#e36a82}
.admin-payment-note{display:inline-flex;align-items:center;border-radius:12px;padding:10px 12px;font-weight:900;border:1px solid #5d789a;background:#10233e;color:#fff}
.admin-payment-note.payment_pending{border-color:#d1a94a;color:#ffe28a;background:#2a230c}
.admin-payment-note.payment_cancelled{border-color:#e36a82;color:#ffc7d0;background:#2b1118}
.admin-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.admin-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-detail-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:18px}
.admin-block{background:rgba(255,255,255,.03);border:1px solid rgba(90,118,160,.4);border-radius:16px;padding:16px}
.admin-block h3{margin:0 0 12px;font-size:22px}
.admin-meta p{margin:0 0 10px;line-height:1.5}
.admin-note{white-space:pre-wrap;word-break:break-word}
.table-wrap{overflow:auto}
.form-select{width:100%;background:#08172d;color:#fff;border:1px solid #4b6a90;border-radius:12px;padding:14px 14px;font-size:16px}
@media (max-width:900px){.admin-grid,.admin-detail-grid{grid-template-columns:1fr}.admin-login-card{max-width:none}.admin-table{font-size:14px}}
@media (max-width:700px){.order-top-actions .back-btn{width:100%;justify-content:center;text-align:center}.radio-card{padding:14px}.field .card{padding:14px}.admin-toolbar{align-items:stretch}.admin-actions{width:100%}.admin-actions .back-btn,.admin-actions .cta{flex:1 1 180px;text-align:center;justify-content:center}.admin-table th,.admin-table td{padding:10px 8px;font-size:13px}.card h2{font-size:42px;line-height:1.05}.review-actions{flex-direction:column;align-items:stretch}.review-actions .back-btn,.review-actions .cta{width:100%;text-align:center;justify-content:center}}


.admin-login-form{display:flex;flex-direction:column;gap:0}
.admin-filters{display:grid;grid-template-columns:minmax(0,1fr) 220px auto;gap:14px;align-items:end;margin-bottom:16px}
.admin-filter-stats{justify-self:end;white-space:nowrap;padding-bottom:10px}
.admin-table-desktop{display:block}
.admin-mobile-list{display:none}
.admin-order-card{border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:14px;background:rgba(255,255,255,.03);display:flex;flex-direction:column;gap:10px}
.admin-order-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.admin-order-number{font-size:20px;font-weight:800;word-break:break-word}
.admin-order-meta{font-size:15px;color:var(--text)}
.admin-open-btn{margin-top:6px;align-self:flex-start}
.admin-meta .field{margin-top:10px}
@media (max-width:900px){
  .admin-filters{grid-template-columns:1fr 1fr;align-items:stretch}
  .admin-filter-stats{grid-column:1 / -1;justify-self:start;padding-bottom:0}
}
@media (max-width:760px){
  .admin-table-desktop{display:none}
  .admin-mobile-list{display:grid;gap:12px}
  .admin-filters{grid-template-columns:1fr}
  .admin-order-number{font-size:18px}
  .admin-block p,.admin-note,.admin-meta p{font-size:15px;line-height:1.45}
}

.admin-shell{max-width:1120px}
.admin-products-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}
.admin-product-card{padding:16px}
.admin-product-slot{font-size:20px;font-weight:800;margin-bottom:8px}
.admin-product-row{display:grid;grid-template-columns:1fr 160px;gap:14px}
.admin-product-row-equal{grid-template-columns:1fr 1fr}
.admin-active-field{display:flex;flex-direction:column;justify-content:flex-end}
.admin-toggle{display:flex;align-items:center;gap:10px;background:#08172d;border:1px solid #4b6a90;border-radius:12px;padding:14px}
.admin-toggle input{width:18px;height:18px}
.slot img.slot-image{width:90px;height:90px;object-fit:cover;border-radius:16px;border:1px solid rgba(255,255,255,.18);background:#fff}
@media (max-width:900px){.admin-products-grid{grid-template-columns:1fr}.admin-product-row,.admin-product-row-equal{grid-template-columns:1fr}}

.admin-slot-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}

.admin-slot-tools{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.admin-delete-slot-btn{padding:12px 14px;font-size:14px;min-width:auto}
.admin-product-card{cursor:grab}
.admin-product-card.dragging{opacity:.5;cursor:grabbing}
.admin-product-card.drag-over{border-color:#b4e74f;box-shadow:0 0 0 2px rgba(180,231,79,.28), inset 0 0 0 1px rgba(180,231,79,.18)}
.admin-slot-number{width:120px;text-align:center;font-weight:700}
.admin-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px;flex-wrap:wrap}
.admin-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-primary-row{display:flex;justify-content:flex-start;gap:12px;flex-wrap:wrap;margin-top:18px}
.admin-add-slot-btn{background:#102441;color:#fff;border-color:#6e8bb1}
@media (max-width:900px){.admin-slot-head{flex-direction:column;align-items:flex-start}.admin-slot-number{width:100%}.admin-slot-tools{width:100%;justify-content:flex-start}.admin-delete-slot-btn{width:100%}}

.shell.admin-shell{width:min(1600px, calc(100vw - 32px));}

@media (max-width:520px){.slot-bundle-select{height:28px;font-size:12px;padding:0 28px 0 10px;background-position:calc(100% - 14px) 10px, calc(100% - 8px) 10px;background-size:5px 5px,5px 5px}.slot-info-btn{min-width:30px;width:30px;height:28px}.slot-info-icon{width:16px;height:16px;font-size:11px}.namebar-bundle{grid-template-columns:30px minmax(0,1fr);gap:8px;padding:6px 8px}.namebar-bundle .namebar-text{text-align:left;justify-self:start}}

/* STEP 8 PRO – Admin Produktbilder + Lieferschein */
.admin-image-preview{min-height:86px;border:1px dashed rgba(162,190,236,.35);border-radius:14px;background:rgba(255,255,255,.035);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#9fb3d1;font-size:13px;margin-top:-4px}
.admin-image-preview img{max-width:100%;max-height:120px;object-fit:contain;display:block;padding:8px}
@media print{.topbar,.admin-actions,.review-actions,.back-btn,.cta{display:none!important}.page{padding:0!important}.shell,.card{box-shadow:none!important;border:0!important;background:#fff!important;color:#111!important}.admin-detail-grid{display:block!important}.summary-line{color:#111!important}}

/* STEP 9 - Supabase product image upload */
.slot-product-img{
  width:100%;
  height:54px;
  object-fit:contain;
  display:block;
  padding:4px;
  box-sizing:border-box;
}
.admin-image-upload{
  border:1px dashed rgba(181,211,255,.45);
  border-radius:14px;
  padding:10px;
  background:rgba(3,14,31,.25);
  transition:border-color .15s ease, background .15s ease;
}
.admin-image-upload.is-dragover{
  border-color:#9fca3b;
  background:rgba(159,202,59,.10);
}
.admin-file-input{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.admin-upload-label{
  display:block;
  text-align:center;
  border:1px solid rgba(181,211,255,.45);
  border-radius:12px;
  padding:9px 10px;
  cursor:pointer;
  font-weight:800;
  color:#e9f2ff;
  background:rgba(255,255,255,.04);
  margin-bottom:10px;
}
.admin-upload-label:hover{
  background:rgba(159,202,59,.16);
  border-color:#9fca3b;
}
.admin-image-preview img{
  max-width:100%;
  max-height:110px;
  object-fit:contain;
}

/* STEP 9.1 – stabile Produktbild-Anzeige im Automaten
   Ziel: jedes Format (quer, hoch, quadratisch) bleibt sauber im Slot, ohne Überlauf. */
.slot-top{
  overflow:hidden;
}
.slot-image-frame{
  width:100%;
  height:148px;
  max-height:calc(100% - 48px);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:4px 6px;
  flex:1 1 auto;
}
.slot-top .slot-product-img{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  object-position:center center;
  display:block;
  padding:0;
  border-radius:10px;
}
.slot-top .img-placeholder{
  flex:0 0 auto;
}
.slot-top .spirals{
  flex:0 0 auto;
  margin-top:0;
}
@media (max-width:900px){
  .slot-image-frame{height:112px;max-height:calc(100% - 42px);}
}
@media (max-width:520px){
  .slot-image-frame{height:92px;max-height:calc(100% - 36px);padding:2px 4px;}
}

/* STEP 10 Design System / Menu / Content */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-right:24px;}
.main-nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.main-nav button{background:rgba(8,25,48,.72);border:1px solid rgba(165,205,255,.35);color:#fff;border-radius:999px;padding:9px 14px;font-weight:800;cursor:pointer;}
.main-nav button:hover{border-color:#c9ff60;color:#dfff8b;}
.shell{background:linear-gradient(180deg,var(--admin-bg, rgba(9,33,67,.95)),rgba(5,20,40,.96));}
.machine-red{border-color:var(--admin-frame,#b22b2b)!important;}
.slot{background:var(--admin-slot,#3d5366)!important;}
.order-btn,.cta.primary{background:var(--admin-button,#65a832)!important;}
.content-shell{max-width:980px;}
.content-card{border:1px solid rgba(124,166,217,.32);border-radius:18px;background:rgba(6,20,41,.72);padding:22px;line-height:1.65;font-size:18px;white-space:normal;}
.contact-card{margin-top:18px;}
.contact-card textarea{min-height:150px;}
input[type="color"]{height:44px;padding:4px;cursor:pointer;}
@media(max-width:760px){.topbar{align-items:flex-start;flex-direction:column;padding-bottom:10px}.main-nav{padding-left:8px}.main-nav button{font-size:12px;padding:8px 10px}}


/* STEP 10.1 CMS Pro */
.cms-pro-shell{max-width:1320px}.cms-layout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.8fr);gap:18px;margin-bottom:18px}.cms-card,.cms-preview{border-radius:18px}.cms-preview{position:sticky;top:88px;align-self:start;background:linear-gradient(180deg,rgba(8,26,49,.92),rgba(4,14,27,.98))}.mini-machine{background:var(--bg-color);padding:16px;border-radius:16px;border:1px solid rgba(142,177,220,.25)}.mini-frame{border:5px solid var(--frame-color);border-radius:14px;padding:14px;background:#172231}.mini-title{font-weight:900;font-size:20px;margin-bottom:8px}.mini-inner{font-weight:800;background:#111b28;border:1px solid rgba(255,255,255,.25);padding:10px;border-radius:8px;margin-bottom:12px}.mini-slot{height:76px;border-radius:12px;background:var(--slot-color);display:grid;place-items:center;margin-bottom:12px}.mini-machine button{background:var(--button-color);color:#fff;border:0;border-radius:10px;padding:10px 18px;font-weight:900}.cms-subhead{margin:22px 0 12px}.cms-pages-list{display:grid;gap:18px}.cms-page-card{border-radius:18px}.cms-page-card.is-inactive{opacity:.65}.cms-page-head{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:12px}.cms-page-head strong{display:block;font-size:20px}.cms-page-head span{font-size:12px;color:#9fb3c8}.cms-page-actions{display:flex;gap:8px;flex-wrap:wrap}.back-btn.danger{border-color:rgba(255,100,100,.55);color:#ffd2d2}.cms-meta-row{grid-template-columns:2fr .7fr auto auto;align-items:end}.cms-check{min-height:42px;align-items:center}.cms-editor{min-height:260px;font-size:15px;line-height:1.55;resize:vertical}.sticky-save{position:sticky;bottom:0;padding:14px 0;background:linear-gradient(180deg,rgba(5,15,28,0),rgba(5,15,28,.95) 35%)}@media(max-width:900px){.cms-layout{grid-template-columns:1fr}.cms-preview{position:static}.cms-meta-row{grid-template-columns:1fr}.cms-page-head{align-items:flex-start;flex-direction:column}}


/* STEP 10.3 – Professional dropdown navigation fix */
.topbar{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:18px!important;min-height:78px!important;height:auto!important;padding:8px clamp(12px,1.8vw,28px)!important;}
.topbar img{flex:0 0 auto!important;}
.nav-dropdown{position:relative;margin-left:auto;display:flex;justify-content:flex-end;align-items:center;z-index:80;}
.menu-toggle{background:rgba(8,25,48,.9);border:1px solid rgba(165,205,255,.55);color:#fff;border-radius:999px;padding:10px 18px;font-weight:900;cursor:pointer;box-shadow:0 8px 26px rgba(0,0,0,.25);}
.menu-toggle::after{content:' ▾';font-size:.85em;color:#dfff8b;}
.main-nav{position:absolute!important;right:0!important;top:calc(100% + 10px)!important;min-width:230px!important;display:none!important;flex-direction:column!important;align-items:stretch!important;gap:8px!important;padding:12px!important;border-radius:18px!important;background:linear-gradient(180deg,rgba(8,25,48,.98),rgba(3,11,22,.98))!important;border:1px solid rgba(165,205,255,.38)!important;box-shadow:0 20px 55px rgba(0,0,0,.55)!important;}
.main-nav.is-open{display:flex!important;}
.main-nav button{width:100%!important;text-align:left!important;white-space:normal!important;border-radius:12px!important;padding:12px 14px!important;font-size:14px!important;line-height:1.2!important;background:rgba(255,255,255,.055)!important;}
.main-nav button:hover{background:rgba(201,255,96,.12)!important;}
@media(max-width:760px){
  .topbar{align-items:center!important;flex-direction:row!important;padding:8px 10px!important;}
  .topbar img{width:128px!important;max-width:45vw!important;}
  .menu-toggle{padding:8px 13px!important;font-size:13px!important;}
  .main-nav{right:0!important;left:auto!important;top:calc(100% + 8px)!important;min-width:min(78vw,260px)!important;max-width:78vw!important;}
  .main-nav button{font-size:13px!important;padding:11px 12px!important;}
  .page{padding-top:14px!important;}
}

/* CMS: more professional editor spacing, until the rich block editor is added */
.cms-editor{min-height:340px!important;font-size:16px!important;line-height:1.65!important;}
.cms-page-card{box-shadow:0 18px 55px rgba(0,0,0,.2);}

/* STEP 10.4 Page Builder Pro */
.cms-builder-zone{margin-top:18px;border:1px solid #33557b;border-radius:18px;padding:16px;background:rgba(0,0,0,.18)}
.cms-builder-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.cms-builder-head span{display:block;color:#bfd0e8;font-size:13px;margin-top:4px}
.cms-add-blocks{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cms-block-list{display:grid;gap:14px}
.cms-block-editor{border:1px solid #44658b;border-radius:16px;padding:14px;background:rgba(4,18,35,.75)}
.cms-block-head{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:12px}
.pb-admin-style-row{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:12px;margin-top:10px}
.cms-editor.small{min-height:96px}
.cms-image-upload-row{display:flex;align-items:center;gap:12px;border:1px dashed #55789f;border-radius:12px;padding:10px;margin:8px 0 12px;background:rgba(255,255,255,.04)}
.cms-image-upload-row span{color:#c6d5eb;font-size:13px}.cms-block-image-preview{border:1px solid #365d86;border-radius:14px;padding:10px;margin:10px 0;display:flex;justify-content:center;background:rgba(255,255,255,.05)}
.cms-block-image-preview img{max-width:220px;max-height:140px;object-fit:contain;border-radius:8px}.page-builder-content{display:grid;gap:18px}.pb-block{color:var(--block-color,#fff);background:var(--block-bg,rgba(9,31,58,.65));border:1px solid rgba(124,164,206,.32);border-radius:18px;padding:20px;line-height:1.55}.pb-heading h2{margin:0;font-size:34px}.pb-text{font-size:18px}.align-left{text-align:left}.align-center{text-align:center}.align-right{text-align:right}.pb-image{background:transparent;border:0;padding:8px}.pb-image img{max-width:100%;max-height:360px;object-fit:contain;border-radius:14px}.pb-button{background:transparent;border:0;padding:8px}.pb-quote blockquote{margin:0;font-size:22px;font-weight:800;border-left:6px solid var(--button-color,#65a832);padding-left:18px}.pb-columns{display:grid;grid-template-columns:1fr 1fr;gap:18px}.pb-columns>div{background:rgba(255,255,255,.04);border-radius:14px;padding:16px}.pb-divider{height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);margin:10px 0}
@media(max-width:760px){.cms-builder-head,.cms-block-head{display:block}.cms-add-blocks{justify-content:flex-start;margin-top:10px}.pb-admin-style-row,.pb-columns{grid-template-columns:1fr}.pb-heading h2{font-size:26px}.pb-text{font-size:16px}}

/* STEP 10.5 – CMS/Page Builder stabilisieren */
.page-fallback-content{margin-bottom:18px;font-size:18px;line-height:1.7;overflow-wrap:anywhere;}
.page-fallback-content h1,.page-fallback-content h2,.page-fallback-content h3{margin:10px 0 8px;color:#fff;line-height:1.2;}
.page-fallback-content h1{font-size:34px}.page-fallback-content h2{font-size:28px}.page-fallback-content h3{font-size:22px}
.page-fallback-content .cms-bullet{position:relative;padding-left:22px;margin:4px 0;}
.page-fallback-content .cms-bullet:before{content:'•';position:absolute;left:4px;color:var(--button-color,#65a832);font-weight:900;}
.empty-page{opacity:.75;font-style:italic;}
.page-builder-content{margin-top:0;}
.pb-block{overflow-wrap:anywhere;}
.pb-image img{display:block;margin-left:auto;margin-right:auto;}
@media(max-width:720px){.page-fallback-content{font-size:16px;padding:16px}.pb-heading h2{font-size:26px}.pb-text{font-size:16px}.pb-quote blockquote{font-size:18px}.pb-columns{grid-template-columns:1fr}.pb-image img{max-height:280px}}

/* STEP 11 – Inventory / Lagerverwaltung */
.inventory-summary{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin:14px 0 18px;
}
.inventory-summary>div{
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.07);
  border-radius:16px;
  padding:14px;
  min-height:76px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.inventory-summary strong{font-size:20px;line-height:1.1;color:#fff}
.inventory-summary span{font-size:12px;color:rgba(255,255,255,.72)}
.inventory-row{align-items:end}
.inventory-status{
  border-radius:14px;
  padding:12px 14px;
  min-height:58px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
}
.inventory-status strong{font-size:12px;color:rgba(255,255,255,.72);font-weight:700}
.inventory-status span{font-size:15px;font-weight:800}
.stock-ok{color:#8ff0a4}
.stock-low{color:#ffd166}
.stock-out{color:#ff7b7b}
.stock-mini{
  margin:3px auto 4px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  background:rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  padding:3px 7px;
  width:max-content;
  max-width:90%;
}
.slot.is-sold-out{
  opacity:.62;
  filter:saturate(.55);
  cursor:not-allowed;
}
.slot.is-sold-out .slot-product-img,
.slot.is-sold-out .img-placeholder{filter:grayscale(.7)}
.soldout-ribbon{
  position:absolute;
  z-index:5;
  top:10px;
  right:8px;
  border-radius:999px;
  padding:5px 9px;
  font-size:10px;
  font-weight:900;
  color:#fff;
  background:rgba(150,25,25,.92);
  box-shadow:0 8px 18px rgba(0,0,0,.28);
}
.slot{position:relative}
@media (max-width:760px){
  .inventory-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .inventory-row{grid-template-columns:1fr!important}
}

/* STEP 11.1 inventory movement UI */
.stock-booking-row{
  display:grid;
  grid-template-columns: minmax(110px, .7fr) minmax(160px, 1fr) auto auto;
  gap:10px;
  align-items:end;
  margin:10px 0 12px;
  padding:10px;
  border:1px solid rgba(130,170,220,.28);
  border-radius:14px;
  background:rgba(3,16,34,.35);
}
.cta.tiny{padding:10px 12px;min-height:42px;font-size:12px;white-space:nowrap}
.inventory-history{margin-top:18px;padding:16px;border:1px solid rgba(130,170,220,.24);border-radius:18px;background:rgba(6,20,44,.45)}
.inventory-history h3{margin:0 0 12px;font-size:18px}
.inventory-history-table{display:grid;gap:6px}
.inventory-history-row{display:grid;grid-template-columns: 150px 1.2fr .8fr 70px 90px;gap:10px;align-items:center;padding:9px 10px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(255,255,255,.035);font-size:12px}
.stock-ok-text{color:#8cffad;font-weight:800}.stock-out-text{color:#ff8b8b;font-weight:800}
@media(max-width:760px){
  .stock-booking-row{grid-template-columns:1fr;}
  .inventory-history-row{grid-template-columns:1fr;gap:4px}
}

/* STEP 11.1.1 – Lager UI Layout-Fix: keine überstehenden Buttons */
.stock-booking-row{
  grid-template-columns: minmax(74px, 90px) minmax(120px, 1fr) !important;
  gap:8px !important;
  align-items:end;
}
.stock-booking-row .field{min-width:0;}
.stock-booking-row .field input{width:100%;min-width:0;box-sizing:border-box;}
.stock-booking-row .cta.tiny{
  width:100%;
  min-width:0;
  box-sizing:border-box;
  white-space:normal;
  line-height:1.15;
  text-align:center;
}
.stock-booking-row .cta.tiny:nth-of-type(1){grid-column:1 / 2;}
.stock-booking-row .cta.tiny:nth-of-type(2){grid-column:2 / 3;}
@media (max-width:980px){
  .stock-booking-row{grid-template-columns:1fr !important;}
  .stock-booking-row .cta.tiny:nth-of-type(1),
  .stock-booking-row .cta.tiny:nth-of-type(2){grid-column:auto;}
}

/* STEP 11.2 Statistik Dashboard */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin:18px 0;
}
.stat-card{
  border:1px solid rgba(130,170,220,.35);
  background:rgba(12,35,64,.78);
  border-radius:18px;
  padding:18px;
  box-shadow:0 16px 42px rgba(0,0,0,.18);
}
.stat-card span{display:block;font-size:13px;color:#c9d9ef;margin-bottom:8px}
.stat-card strong{display:block;font-size:30px;line-height:1.05;color:#fff}
.stat-card small{display:block;margin-top:8px;color:#9fb4cd}
.analytics-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
  align-items:start;
}
.analytics-card h3{margin-top:0}
.bar-chart{display:grid;gap:9px}
.bar-row{display:grid;grid-template-columns:52px 1fr 92px;gap:10px;align-items:center;font-size:13px}
.bar-row div{height:16px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid rgba(130,170,220,.25)}
.bar-row i{display:block;height:100%;border-radius:999px;background:var(--button-color,#65a832);min-width:4px}
.bar-row strong{text-align:right}
.top-products{display:grid;gap:8px}
.top-product-row{display:grid;grid-template-columns:28px 1fr 64px 90px;gap:8px;align-items:center;border-bottom:1px solid rgba(130,170,220,.16);padding:8px 0}
.top-product-row span{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);font-weight:800}
.top-product-row em{font-style:normal;color:#c9d9ef;text-align:right}
.top-product-row b{text-align:right}
.status-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.status-overview div{border:1px solid rgba(130,170,220,.25);border-radius:14px;padding:14px;background:rgba(255,255,255,.04)}
.status-overview span{display:block;color:#c9d9ef;margin-bottom:6px}.status-overview strong{font-size:26px}
@media (max-width:900px){.stats-grid,.analytics-grid,.status-overview{grid-template-columns:1fr}.bar-row{grid-template-columns:48px 1fr 76px}.top-product-row{grid-template-columns:28px 1fr}.top-product-row em,.top-product-row b{text-align:left}}

/* STEP 11.3 CRM */
.crm-stats { margin: 18px 0; }
.crm-toolbar { display:grid; grid-template-columns: 1.4fr .7fr auto auto; gap:14px; align-items:end; }
.crm-newsletter-box { margin: 16px 0; }
.crm-newsletter-box h3 { margin:0 0 8px; font-size:22px; }
.crm-card { border:1px solid rgba(140,178,230,.28); background:rgba(8,28,55,.72); border-radius:18px; padding:16px; display:grid; gap:12px; }
.crm-card strong { display:block; font-size:16px; }
.crm-card span { display:block; color:#b9cdeb; font-size:13px; margin-top:4px; }
.crm-card-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:8px; }
.crm-card-grid em { font-style:normal; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:10px; font-size:12px; color:#b9cdeb; }
.crm-card-grid b { color:#fff; font-size:15px; }
@media (max-width: 900px){
  .crm-toolbar { grid-template-columns: 1fr; }
  .crm-card-grid { grid-template-columns: 1fr; }
}

/* STEP 11.4 Newsletter Pro */
.newsletter-media-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:end;margin-top:12px}
.newsletter-preview{margin:12px 0;padding:14px;border:1px dashed rgba(132,169,210,.55);border-radius:14px;background:rgba(255,255,255,.04);display:flex;justify-content:center;align-items:center;min-height:120px}
.newsletter-preview img{max-width:100%;max-height:260px;object-fit:contain;border-radius:10px}
.newsletter-actions{display:flex;gap:12px;justify-content:flex-end;align-items:center;margin-top:14px;flex-wrap:wrap}
.newsletter-actions .cta,.newsletter-actions .back-btn{min-width:170px}
@media(max-width:760px){.newsletter-media-grid{grid-template-columns:1fr}.newsletter-actions{justify-content:stretch}.newsletter-actions .cta,.newsletter-actions .back-btn{width:100%}}


.admin-row-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.admin-row-actions .back-btn.mini{padding:8px 12px;font-size:13px;min-width:0}.back-btn.danger{border-color:#ff5b6b;color:#fff;background:rgba(120,20,35,.22)}.back-btn.danger:hover{background:rgba(180,35,55,.34)}.back-btn:disabled{opacity:.45;cursor:not-allowed}.card-actions{justify-content:flex-start;margin-top:12px}.admin-table th:last-child,.admin-table td:last-child{text-align:right;min-width:270px}@media(max-width:760px){.admin-row-actions{justify-content:stretch}.admin-row-actions .back-btn{flex:1 1 100%;text-align:center;justify-content:center}.admin-table th:last-child,.admin-table td:last-child{text-align:left;min-width:0}}

/* STEP 11.6.14 small corrections: bundle info button + inventory overview */
.namebar-bundle-clean{display:flex;align-items:center;justify-content:center;text-align:center;padding:8px 10px}
.namebar-bundle-clean .namebar-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-align:center;line-height:1.15;word-break:break-word}
.slot-info-wide-btn{width:100%;min-height:30px;margin-top:6px;border-radius:9px;border:1px solid rgba(141,178,215,.45);background:linear-gradient(180deg,#15283b,#09131d);color:#efff87;font-weight:800;font-size:13px;cursor:pointer;text-align:center}
.slot-info-wide-btn:hover{filter:brightness(1.12)}
.slot-bundle .select-light{margin-top:6px}
.inventory-overview-card{margin-top:18px}
.inventory-overview-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}
.inventory-overview-head h3{margin:0}
.inventory-overview-table{display:grid;gap:6px}
.inventory-overview-row{display:grid;grid-template-columns:70px 1.5fr .7fr .7fr .7fr .8fr;gap:10px;align-items:center;padding:9px 10px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(255,255,255,.035);font-size:12px}
.inventory-overview-row-head{font-weight:900;color:#ffe16a;background:rgba(255,255,255,.06)}
@media(max-width:700px){.inventory-overview-head{align-items:stretch;flex-direction:column}.inventory-overview-row{grid-template-columns:1fr 1fr;gap:6px}.inventory-overview-row-head{display:none}.slot-info-wide-btn{min-height:28px;font-size:12px}}


/* STEP 11.6.21 – Produktkachel-Feinschliff
   Ziel: Produktname bleibt sauber zentriert, Info-Button bleibt eigener schmaler Button.
   Keine Speicherlogik, keine API, kein Layout-Umbau. */
.slot-name,
.product-name,
.slot-title,
.product-title,
.vending-slot .name,
.machine-slot .name {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  min-height: 44px !important;
  padding: 6px 10px !important;
  line-height: 1.12 !important;
  white-space: normal !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  word-break: normal !important;
  hyphens: auto !important;
}

.slot-name .info-dot,
.product-name .info-dot,
.slot-title .info-dot,
.product-title .info-dot,
.vending-slot .name .info-dot,
.machine-slot .name .info-dot {
  flex: 0 0 auto !important;
  margin-right: 8px !important;
}

.bundle-info-btn,
.slot-info-btn,
.info-content-btn,
button[data-action="bundle-info"] {
  width: 100% !important;
  min-height: 24px !important;
  height: 24px !important;
  margin: 4px 0 5px 0 !important;
  padding: 2px 8px !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  text-align: center !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #10202b !important;
  color: #f4ff70 !important;
  border: 1px solid rgba(184, 220, 255, 0.25) !important;
}

.bundle-option-label,
.slot-option-label,
.product-option-label {
  display: none !important;
}

@media (max-width: 760px) {
  .slot-name,
  .product-name,
  .slot-title,
  .product-title,
  .vending-slot .name,
  .machine-slot .name {
    min-height: 40px !important;
    padding: 5px 8px !important;
    font-size: 13px !important;
    line-height: 1.08 !important;
  }

  .bundle-info-btn,
  .slot-info-btn,
  .info-content-btn,
  button[data-action="bundle-info"] {
    min-height: 22px !important;
    height: 22px !important;
    font-size: 11px !important;
    margin: 3px 0 4px 0 !important;
  }
}


/* STEP 11.6.22 – nur Produktname-Button sauber zentrieren.
   Wichtig: keine Speicherlogik, kein Warenkorbtext, keine API. */
.namebar {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  min-height: 54px !important;
  max-height: 54px !important;
  padding: 7px 10px !important;
  overflow: hidden !important;
  line-height: 1.12 !important;
  word-break: normal !important;
  white-space: normal !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
}

.namebar .namebar-text {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  width: 100% !important;
  text-align: center !important;
  justify-self: center !important;
  align-self: center !important;
  line-height: 1.12 !important;
  word-break: normal !important;
  hyphens: auto !important;
}

.namebar-bundle {
  display: grid !important;
  grid-template-columns: 34px minmax(0, 1fr) 34px !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 8px !important;
}

.namebar-bundle::after {
  content: "" !important;
  display: block !important;
  width: 34px !important;
}

.namebar-bundle .slot-info-btn,
.namebar-bundle .slot-info-icon {
  grid-column: 1 !important;
}

.namebar-bundle .namebar-text {
  grid-column: 2 !important;
  text-align: center !important;
  justify-self: center !important;
}

.slot-info-strip {
  width: 100% !important;
  height: 24px !important;
  min-height: 24px !important;
  margin: 4px 0 5px 0 !important;
  padding: 2px 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  background: #10202b !important;
  color: #f4ff70 !important;
  border: 1px solid rgba(184, 220, 255, 0.25) !important;
}

@media (max-width: 760px) {
  .namebar {
    min-height: 46px !important;
    max-height: 46px !important;
    padding: 5px 8px !important;
  }

  .namebar-bundle {
    grid-template-columns: 30px minmax(0, 1fr) 30px !important;
    gap: 5px !important;
  }

  .namebar-bundle::after {
    width: 30px !important;
  }

  .namebar .namebar-text {
    font-size: 13px !important;
    line-height: 1.08 !important;
  }

  .slot-info-strip {
    height: 22px !important;
    min-height: 22px !important;
    font-size: 11px !important;
  }
}

/* STEP 14.2 CMS Builder Professional */
.cms-block-editor[draggable="true"]{cursor:grab;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease,opacity .15s ease;}
.cms-block-editor.is-dragging{opacity:.55;cursor:grabbing;transform:scale(.995);}
.cms-block-editor.is-drag-over{border-color:#65a832!important;box-shadow:0 0 0 2px rgba(101,168,50,.35),0 0 18px rgba(101,168,50,.25);}
.cms-drag-handle{display:inline-flex;align-items:center;justify-content:center;margin-right:8px;color:#9fc7ff;font-weight:900;cursor:grab;user-select:none;}
.cms-page-preview-box{margin-top:16px;border:1px solid rgba(150,190,255,.28);border-radius:18px;padding:14px;background:rgba(3,15,31,.45);}
.cms-page-preview-title{font-weight:900;margin-bottom:10px;color:#dcecff;}
.cms-page-preview-content{border:1px dashed rgba(150,190,255,.28);border-radius:14px;padding:14px;background:rgba(0,0,0,.18);}
.cms-page-preview-content .content-card{margin:0 0 12px 0;}
.cms-page-preview-content .pb-block{margin-left:0;margin-right:0;}

/* STEP 14.3 CMS Builder Komfort */
.cms-block-head-tools{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.cms-inline-check{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid rgba(148,190,255,.35);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:800;
  color:#eef6ff;
  background:rgba(5,18,34,.55);
  white-space:nowrap;
}
.cms-inline-check input{ width:auto; accent-color:#65a832; }
.cms-block-editor.is-collapsed{
  background:rgba(5,18,34,.54);
}
.cms-block-editor.is-disabled{
  opacity:.62;
  border-style:dashed;
}
.cms-collapsed-note{
  margin-top:10px;
  border:1px dashed rgba(148,190,255,.35);
  border-radius:14px;
  padding:12px;
}
@media(max-width:760px){
  .cms-block-head-tools{justify-content:flex-start;width:100%;}
  .cms-inline-check{padding:7px 10px;}
}

/* STEP 14.5 – Mobile Portrait Produktname lesbar
   Nur CSS: verhindert abgeschnittene Namen im grünen Produktbutton auf Smartphones hochkant.
   Keine Änderung an Shoplogik, Warenkorb, CMS oder Speicherung. */
@media (max-width: 520px) and (orientation: portrait) {
  .namebar {
    min-height: 62px !important;
    max-height: 62px !important;
    padding: 6px 7px !important;
  }

  .namebar .namebar-text {
    -webkit-line-clamp: 3 !important;
    font-size: 12px !important;
    line-height: 1.08 !important;
    hyphens: none !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }

  .namebar-bundle {
    min-height: 62px !important;
    grid-template-columns: 28px minmax(0, 1fr) 28px !important;
  }

  .namebar-bundle::after {
    width: 28px !important;
  }
}

/* STEP 19C – Mobile Shop Polish Android/iOS
   Ziel: Produktnamen auf schmalen Smartphones lesbar, keine Buchstaben-Spalten,
   und gewählte Produkte zeigen überall stabil den grünen Rahmen. Nur CSS/kleiner UI-State, keine Shop-Logik. */
.slot.selected,
.slot:active,
.slot:focus {
  border-color:#b4e74f !important;
  box-shadow:inset 0 0 0 2px #32455d,0 0 0 3px rgba(180,231,79,.28),0 0 18px rgba(180,231,79,.22) !important;
}

.namebar,
.namebar-bundle {
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
}
.namebar-bundle::after{content:none !important;display:none !important;}
.namebar .namebar-text,
.namebar-bundle .namebar-text {
  width:100% !important;
  max-width:100% !important;
  text-align:center !important;
  justify-self:center !important;
  grid-column:auto !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
  hyphens:auto !important;
}

@media (max-width:520px) and (orientation:portrait){
  .grid{gap:9px !important;}
  .slot{padding:7px !important;}
  .namebar,
  .namebar-bundle{
    min-height:58px !important;
    max-height:58px !important;
    padding:6px 6px !important;
  }
  .namebar .namebar-text,
  .namebar-bundle .namebar-text{
    display:-webkit-box !important;
    -webkit-box-orient:vertical !important;
    -webkit-line-clamp:3 !important;
    overflow:hidden !important;
    font-size:clamp(11px,3.05vw,13px) !important;
    line-height:1.08 !important;
    letter-spacing:-0.1px !important;
    word-break:normal !important;
    overflow-wrap:normal !important;
    hyphens:auto !important;
  }
  .slot-info-strip{
    height:24px !important;
    min-height:24px !important;
    font-size:11px !important;
    padding:2px 5px !important;
  }
  .slot-bundle-select{font-size:12px !important;}
}

@media (max-width:380px) and (orientation:portrait){
  .namebar,
  .namebar-bundle{
    min-height:60px !important;
    max-height:60px !important;
    padding:5px 5px !important;
  }
  .namebar .namebar-text,
  .namebar-bundle .namebar-text{
    font-size:11px !important;
    line-height:1.05 !important;
  }
}

/* STEP 19B - Inventory Pro / Admin polish */
.pro-kpis{grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:10px}.pro-kpis>div{min-height:60px}.quick-filter-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:12px 0 18px;padding:12px}.quick-filter-bar strong{margin-right:6px}.back-btn.is-active,.inventory-filter-row .is-active{border-color:#c8ff62;box-shadow:0 0 0 1px rgba(200,255,98,.5),0 0 18px rgba(200,255,98,.18);color:#eaff9a}.inventory-movements{margin-top:16px}.inventory-filter-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.inventory-pill.stock-ok{color:#62ff91}.inventory-pill.stock-low{color:#ffd45c}.inventory-pill.stock-out{color:#ff6b87}.inventory-pill.movement-sale{color:#78d8ff}.inventory-pill.movement-restock{color:#62ff91}.inventory-pill.movement-manual,.inventory-pill.movement-set{color:#ffd45c}.maintenance-admin-box{border:1px solid rgba(130,170,220,.35);background:rgba(255,255,255,.04);border-radius:14px;padding:12px;margin:10px 0 14px}.maintenance-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 30%,#0d2442 0,#061527 55%,#020912 100%);color:white;padding:22px}.maintenance-card{width:min(520px,92vw);border:1px solid rgba(120,170,230,.35);background:rgba(6,21,39,.88);border-radius:22px;text-align:center;padding:34px 28px;box-shadow:0 24px 70px rgba(0,0,0,.45)}.maintenance-card img{width:190px;max-width:70%;height:auto;margin-bottom:18px}.maintenance-card h1{font-size:clamp(2rem,6vw,3.4rem);margin:0 0 12px}.maintenance-card p{color:#dbe8ff;line-height:1.5}.maintenance-card span{display:inline-block;margin-top:10px;color:#d7b044;font-weight:900;letter-spacing:.18em}@media(max-width:700px){.pro-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-filter-bar{position:sticky;top:0;z-index:5}.inventory-overview-table{overflow-x:auto}.inventory-overview-table table{min-width:760px}.inventory-filter-row{justify-content:flex-start}.admin-products-grid .admin-product-card{margin-bottom:12px}.admin-slot-head{gap:8px}.admin-slot-tools{width:100%;justify-content:space-between}.admin-slot-tools .field{max-width:120px}.admin-product-card{padding:14px}.sticky-save{position:sticky;bottom:0;z-index:10;background:linear-gradient(180deg,rgba(6,21,39,.05),rgba(6,21,39,.95));padding:10px 0}.sticky-save .cta{width:100%}}

/* STEP 19D - Slot info for all products */
.product-info-list{margin:0;padding:0 0 0 18px;display:grid;gap:8px;color:#fff;font-weight:700}
.product-info-list li{padding-left:4px;line-height:1.35}
.admin-info-toggle-field{max-width:260px;margin:12px 0 0}
.slot-info-strip{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:760px){
  .slot-info-strip{font-size:10px!important;padding-left:4px!important;padding-right:4px!important}
  .product-info-list{font-size:15px;gap:7px}
}
.admin-help{
  display:block;
  margin-top:6px;
  color:rgba(221,235,255,.68);
  font-size:11px;
  line-height:1.25;
}


.order-btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.35)}
.min-order-note{font-size:11px;line-height:1.25;margin:8px 0 4px;padding:7px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.18)}
.min-order-note.warn{color:#ffe46a;border-color:rgba(255,228,106,.35)}
.min-order-note.ok{color:#baff67;border-color:rgba(186,255,103,.28)}

/* STEP19I - optional product image popup */
.slot-image-frame.is-clickable{cursor:zoom-in;position:relative;}
.slot-image-frame.is-clickable::after{content:'+';position:absolute;right:7px;bottom:6px;width:20px;height:20px;border-radius:999px;background:rgba(8,18,32,.82);border:1px solid rgba(210,255,112,.65);color:#dfff67;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;line-height:1;box-shadow:0 0 12px rgba(210,255,112,.25);opacity:.92;}
.slot-image-frame.is-clickable:hover{box-shadow:0 0 0 2px rgba(210,255,112,.7), inset 0 0 18px rgba(210,255,112,.08);}
.product-image-modal{max-width:min(760px,92vw);width:max-content;padding:18px;}
.product-image-modal h3{margin:0 42px 12px 0;font-size:24px;line-height:1.2;}
.product-image-modal-frame{background:#fff;border-radius:14px;border:1px solid rgba(255,255,255,.3);padding:18px;display:flex;align-items:center;justify-content:center;max-height:74vh;}
.product-image-modal-frame img{max-width:min(680px,82vw);max-height:68vh;width:auto;height:auto;object-fit:contain;display:block;}
.admin-toggle-row{align-items:end;}
@media(max-width:700px){.product-image-modal{width:92vw;}.product-image-modal-frame{padding:12px;}.product-image-modal h3{font-size:20px}.slot-image-frame.is-clickable::after{width:18px;height:18px;font-size:13px;}}

/* STEP 20A - Produkt-Galerie pro Slot */
.admin-gallery-panel{margin-top:10px;border:1px dashed rgba(133,170,219,.45);border-radius:14px;padding:10px;background:rgba(4,16,35,.28)}
.admin-gallery-panel textarea{min-height:72px;resize:vertical}
.admin-gallery-upload-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px}
.admin-gallery-upload-row small{opacity:.78;font-size:.78rem}
.admin-gallery-manager{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:10px}
.admin-gallery-item{position:relative;display:grid;grid-template-columns:58px 1fr;gap:8px;align-items:center;padding:8px;border:1px solid rgba(133,170,219,.35);border-radius:12px;background:rgba(7,18,38,.55)}
.admin-gallery-item.is-main{border-color:rgba(79,255,126,.75);box-shadow:0 0 0 1px rgba(79,255,126,.18),0 0 18px rgba(79,255,126,.12)}
.admin-gallery-item img{width:58px;height:58px;object-fit:contain;background:#fff;border:1px solid rgba(133,170,219,.45);border-radius:9px;padding:4px}
.admin-gallery-item-actions{display:flex;gap:5px;flex-wrap:wrap}
.tiny-ghost,.tiny-danger{border:1px solid rgba(133,170,219,.45);border-radius:999px;background:rgba(255,255,255,.06);color:#e8f0ff;padding:5px 8px;font-size:.72rem;cursor:pointer}
.tiny-ghost:disabled,.tiny-danger:disabled{opacity:.35;cursor:not-allowed}
.tiny-danger{border-color:rgba(255,94,94,.5);color:#ffd6d6}
.admin-gallery-main-badge{position:absolute;top:6px;left:6px;border-radius:999px;padding:2px 7px;background:rgba(79,255,126,.92);color:#06121f;font-size:.68rem;font-weight:900}
.admin-gallery-empty{margin-top:8px;padding:9px;border-radius:10px;background:rgba(255,255,255,.05);color:#b8c7df;font-size:.82rem}
.product-image-gallery-thumbs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:12px;max-width:min(88vw,720px)}
.product-gallery-thumb{width:64px;height:52px;border:1px solid rgba(133,170,219,.55);border-radius:9px;background:rgba(5,17,34,.85);padding:4px;cursor:pointer;opacity:.78;transition:opacity .15s ease,transform .15s ease,border-color .15s ease}
.product-gallery-thumb:hover,.product-gallery-thumb.is-active{opacity:1;transform:translateY(-1px);border-color:#c9ff5a}
.product-gallery-thumb img{width:100%;height:100%;object-fit:contain;background:#fff;border-radius:5px}
.product-image-modal-frame img{max-height:min(66vh,720px)}
@media(max-width:760px){.product-gallery-thumb{width:56px;height:46px}.admin-gallery-manager{grid-template-columns:1fr}.admin-gallery-item{grid-template-columns:54px 1fr}.admin-gallery-item img{width:54px;height:54px}}

/* STEP 20B – CMS Pro Logo/Minimum Order Preview */
.cms-logo-preview img{max-height:80px;object-fit:contain;background:#07131f;padding:10px;border-radius:10px;}
.mini-logo-preview{display:block;max-width:150px;max-height:42px;object-fit:contain;margin:0 auto 8px;}

/* STEP 20D - Statistik Pro */
.analytics-pro-shell .analytics-kpis{
  grid-template-columns:repeat(3,minmax(170px,1fr));
}
.stat-card.warn-card{
  border-color:rgba(255,210,90,.6);
  box-shadow:0 0 0 1px rgba(255,210,90,.18) inset;
}
.stat-card.warn-card strong{color:#ffd95c}
.stat-card.danger-card{
  border-color:rgba(255,91,122,.65);
  box-shadow:0 0 0 1px rgba(255,91,122,.18) inset;
}
.stat-card.danger-card strong{color:#ff6b86}
.analytics-grid-wide{
  grid-template-columns:1.35fr .95fr;
}
.analytics-stock-list,.analytics-order-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.analytics-stock-row,.analytics-order-row{
  display:grid;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  border:1px solid rgba(126,169,214,.22);
  border-radius:12px;
  background:rgba(3,15,31,.34);
  font-size:13px;
}
.analytics-stock-row{
  grid-template-columns:42px 1fr 110px 64px;
}
.analytics-stock-row span{
  color:#dbeafe;
  font-weight:900;
}
.analytics-stock-row strong{color:#fff}
.analytics-stock-row em{
  font-style:normal;
  color:#d7e8ff;
  text-align:right;
}
.analytics-stock-row b{
  text-align:center;
  border-radius:999px;
  padding:4px 7px;
  color:#08111d;
}
.analytics-stock-row.is-low b{background:#ffd95c}
.analytics-stock-row.is-empty b{background:#ff6b86;color:#fff}
.analytics-order-row{
  grid-template-columns:1.15fr 1fr .85fr .7fr .9fr;
}
.analytics-order-row strong{color:#fff}
.analytics-order-row span,.analytics-order-row em,.analytics-order-row i{
  color:#cfe3ff;
  font-style:normal;
}
.analytics-order-row b{
  color:#ffec6e;
  text-align:right;
}
.status-overview-pro{
  grid-template-columns:repeat(2,minmax(120px,1fr));
}
.success-note{
  color:#7cff9f;
  border:1px solid rgba(124,255,159,.2);
  padding:12px;
  border-radius:12px;
  background:rgba(72,160,80,.08);
}
@media (max-width:900px){
  .analytics-pro-shell .analytics-kpis,.analytics-grid-wide{grid-template-columns:1fr}
  .analytics-stock-row{grid-template-columns:38px 1fr;}
  .analytics-stock-row em,.analytics-stock-row b{text-align:left}
  .analytics-order-row{grid-template-columns:1fr;}
  .analytics-order-row b{text-align:left}
}

/* STEP 20E – Automaten Design Control */
.shop-design-page{
  background:var(--shop-bg,#061527);
  background-repeat:no-repeat;
  transition:background .25s ease;
}
.shop-design-shell{
  background:linear-gradient(180deg, rgba(10,30,63,.80), rgba(6,17,40,.92));
  backdrop-filter:blur(1px);
}
.machine{
  background:linear-gradient(180deg,color-mix(in srgb,var(--machine-body,#9ba0a4) 88%,#fff 12%),color-mix(in srgb,var(--machine-body,#9ba0a4) 72%,#000 28%)) !important;
  box-shadow:inset 0 0 0 4px color-mix(in srgb,var(--machine-body,#9ba0a4) 70%,#fff 30%), inset 0 0 0 7px rgba(0,0,0,.32), 0 24px 60px rgba(0,0,0,.44) !important;
}
.machine-red{
  background:linear-gradient(180deg,var(--admin-frame,#b22b2b),color-mix(in srgb,var(--admin-frame,#b22b2b) 70%,#000 30%)) !important;
}
.machine-inner{
  background:linear-gradient(180deg,color-mix(in srgb,var(--machine-inner,#35414b) 88%,#fff 12%),color-mix(in srgb,var(--machine-inner,#35414b) 78%,#000 22%)) !important;
}
.machine-banner{
  background:linear-gradient(90deg,color-mix(in srgb,var(--machine-banner,#111722) 82%,#000 18%),color-mix(in srgb,var(--machine-banner,#111722) 78%,#fff 22%),color-mix(in srgb,var(--machine-banner,#111722) 82%,#000 18%)) !important;
}
.slot{
  background:linear-gradient(180deg,color-mix(in srgb,var(--admin-slot,#3d5366) 90%,#fff 10%),color-mix(in srgb,var(--admin-slot,#3d5366) 76%,#000 24%)) !important;
}
.namebar,
.cta.primary,
.order-btn{
  background:linear-gradient(180deg,color-mix(in srgb,var(--admin-button,#65a832) 92%,#fff 8%),color-mix(in srgb,var(--admin-button,#65a832) 78%,#000 22%)) !important;
}
.price,
.led .amount,
.led .currency,
.led .small{
  color:var(--machine-price,#f4d870) !important;
}
.select-light span,
.dot.green{
  background:var(--machine-glow,#d7fb77) !important;
  box-shadow:0 0 18px color-mix(in srgb,var(--machine-glow,#d7fb77) 70%,transparent) !important;
}
.cartbox,
.led{
  background:linear-gradient(180deg,color-mix(in srgb,var(--machine-panel,#34414a) 86%,#fff 9%),color-mix(in srgb,var(--machine-panel,#34414a) 82%,#000 18%)) !important;
}
.design-presets{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 14px}
.design-presets .back-btn{font-size:13px;padding:10px 12px}
.design-presets .back-btn.is-active{border-color:#d7fb77;box-shadow:0 0 0 2px rgba(215,251,119,.18);color:#efff87}
.cms-preview{
  background-color:var(--bg-color,#061527);
  background-repeat:no-repeat;
}
.cms-preview .mini-machine{background:color-mix(in srgb,var(--machine-body,#9ba0a4) 86%,#fff 14%)}
.cms-preview .mini-frame{background:color-mix(in srgb,var(--machine-inner,#35414b) 86%,#000 14%);border-color:var(--frame-color,#b22b2b)}
.cms-preview .mini-inner{background:var(--machine-banner,#111722)}
.cms-preview .mini-slot{background:var(--slot-color,#3d5366)}
.cms-preview button{background:var(--button-color,#65a832)!important}

/* STEP 20H - CMS Bedienung Pro */
.cms-design-section-title{
  margin:18px 0 8px;
  padding:8px 10px;
  border:1px solid rgba(125,170,220,.25);
  border-radius:12px;
  background:rgba(7,24,48,.55);
  color:#eaf4ff;
  font-weight:900;
  letter-spacing:.2px;
}
.design-presets{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin:8px 0 6px;
}
.design-presets .back-btn.is-active{
  border-color:#d7fb77;
  box-shadow:0 0 0 2px rgba(215,251,119,.18), 0 0 18px rgba(215,251,119,.18);
  color:#f4ffba;
}
.cms-card .field select[data-design-field="bgPosition"],
.cms-card .field select[data-block-field="bgPosition"]{
  min-height:46px;
  font-weight:800;
}
.cms-card .note{
  line-height:1.35;
}
@media (max-width: 760px){
  .design-presets .back-btn{flex:1 1 46%;}
  .cms-design-section-title{font-size:13px;}
}

/* STEP 22D – Admin FR preservation + readable info button
   Only fixes: FR fields are no longer visually overwritten by DE on rerender;
   long info-button labels are made readable instead of being cut off in one line. */
.slot-info-strip{
  height:auto !important;
  min-height:24px !important;
  max-height:34px !important;
  line-height:1.08 !important;
  white-space:normal !important;
  overflow:hidden !important;
  text-overflow:clip !important;
  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
  align-items:center !important;
  justify-content:center !important;
  overflow-wrap:anywhere !important;
}
@media (max-width:760px){
  .slot-info-strip{
    min-height:24px !important;
    max-height:36px !important;
    font-size:10px !important;
    line-height:1.05 !important;
    padding:3px 4px !important;
  }
}
