/* KioskOrderConfigApp layout & sidebar styles */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
.koc-app{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;height:100%;display:flex;overflow:hidden;background:#F4F3EF;font-size:14px;}

/* ── SIDEBAR ── */
.sidebar{width:240px;min-width:240px;background:#1C1C1E;display:flex;flex-direction:column;overflow:hidden;z-index:10;transition:width .25s cubic-bezier(.4,0,.2,1),min-width .25s;}
.sidebar.closed{width:0;min-width:0;}
.sb-top{padding:22px 18px 16px;}
.sb-logo{font-size:16px;font-weight:600;color:#fff;letter-spacing:-.02em;white-space:nowrap;}
.sb-layout{margin-top:4px;font-size:11px;color:rgba(255,255,255,0.3);letter-spacing:.03em;white-space:nowrap;}
.sb-save-toast{margin-top:8px;font-size:11px;color:#34C759;display:flex;align-items:center;gap:4px;opacity:0;transform:translateY(-4px);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);pointer-events:none;}
.sb-save-toast.visible{opacity:1;transform:translateY(0);}
.sb-scroll{flex:1;overflow-y:auto;scrollbar-width:none;padding:8px 10px 20px;}
.sb-group{margin-top:18px;}
.sb-group-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,0.22);padding:0 10px 8px;white-space:nowrap;}
.sb-item{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:14px 12px;border-radius:10px;font-size:15px;color:rgba(255,255,255,0.45);cursor:pointer;transition:all .15s;margin-bottom:2px;background:transparent;border:none;width:100%;text-align:left;outline:none;user-select:none;white-space:nowrap;touch-action:manipulation;}
.sb-item:hover{background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.8);}
.sb-item.on{background:rgba(255,255,255,0.1);color:#fff;font-weight:500;}
.sb-icon{width:18px;height:18px;opacity:.6;flex-shrink:0;}
.sb-item.on .sb-icon{opacity:1;}
.sb-bottom{padding:16px;border-top:.5px solid rgba(255,255,255,0.07);display:flex;flex-direction:column;gap:8px;}
.sb-btn-reset{font-family:'Inter',sans-serif;font-size:13px;padding:12px;border-radius:10px;border:.5px solid rgba(255,255,255,0.12);background:transparent;color:rgba(255,255,255,0.35);cursor:pointer;width:100%;transition:all .15s;outline:none;white-space:nowrap;touch-action:manipulation;}
.sb-btn-reset:hover{color:rgba(255,255,255,0.6);border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.03);}

/* ── MAIN CONTENT ── */
.koc-main{flex:1;display:flex;position:relative;overflow:hidden;max-width:1600px;margin:0 auto;width:100%;}
.pv-btn{position:absolute;z-index:20;background:rgba(255,255,255,0.92);border:.5px solid rgba(0,0,0,0.10);border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:#555;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:all .15s;outline:none;touch-action:manipulation;}
.pv-btn:hover{background:#fff;color:#111;box-shadow:0 2px 8px rgba(0,0,0,0.08);}
.pv-btn-sb{top:14px;left:14px;}
.pv-btn-opts{top:14px;right:14px;}

/* ── TWO-COLUMN TAB LAYOUT ── */
.tab-2col{display:flex;flex:1;height:100%;overflow:hidden;}
.tab-preview-col{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#F4F3EF;padding:14px;}
.tab-opts-col{width:0;overflow:hidden;background:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:width .28s cubic-bezier(.4,0,.2,1);}
.tab-opts-col.open{width:clamp(460px, 35vw, 620px);}
.tab-opts-col.wide.open{width:auto;flex:1;}

/* ── KIOSK PREVIEW ── */
.kiosk-wrap{
    display:flex;
    align-items:center;
    justify-content:center;
    aspect-ratio:9/16;
    height:min(calc(100% - 4px), calc(100vh - 104px));
    max-height:min(720px, 85vh);
    width:auto;
    max-width:100%;
}
.kiosk{
    position:relative;
    overflow:hidden;
    width:100%;
    height:100%;
    border-radius:18px;
    box-shadow:0 8px 32px rgba(0,0,0,0.18),0 2px 8px rgba(0,0,0,0.10);
    background:#fff;
    display:flex;
    flex-direction:column;
    flex-shrink:0;
    container-type:inline-size;
}

.k-hd{height:28px;display:flex;align-items:center;padding:0 6px;gap:4px;flex-shrink:0;}
.k-logobar{width:20px;height:16px;border-radius:4px;background:rgba(255,255,255,0.35);flex-shrink:0;}
.k-searchbar{flex:1;height:10px;background:rgba(255,255,255,0.2);border-radius:5px;margin:0 4px;}
.k-body{flex:1;display:flex;overflow:hidden;}
.k-side{width:24px;display:flex;flex-direction:column;gap:2px;padding:3px;flex-shrink:0;}
.k-cat{height:10px;border-radius:2px;background:rgba(255,255,255,0.2);flex-shrink:0;}
.k-cat.ka{background:rgba(255,255,255,0.55);}
.k-prods{flex:1;display:grid;gap:2px;padding:2px;overflow:hidden;align-content:start;}
.k-prod{border-radius:4px;aspect-ratio:1;display:flex;align-items:flex-end;justify-content:center;padding-bottom:2px;}
.k-prod-lbl{font-size:4px;color:#fff;font-weight:600;}
.k-foot{height:18px;display:flex;align-items:center;flex-shrink:0;padding:0 4px;}
.k-cart{flex:1;height:12px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:4px;font-weight:700;}
.k-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:8px;}
.k-welcome-logo{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.3);}
.k-welcome-txt{font-size:7px;font-weight:700;text-align:center;letter-spacing:.04em;}
.k-welcome-btn{padding:4px 14px;border-radius:10px;font-size:5px;font-weight:700;text-align:center;}
.k-mode-row{display:flex;gap:4px;padding:0 6px;justify-content:center;}
.k-mode-btn{flex:1;min-height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:4px;font-weight:700;color:#fff;text-align:center;padding:2px;}
.k-overlay{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;}
.k-dialog{display:flex;flex-direction:column;gap:4px;padding:6px;box-shadow:0 2px 8px rgba(0,0,0,0.15);width:80%;}
.k-dlg-title{font-size:5px;font-weight:700;text-align:center;color:#333;}
.k-dlg-btn{height:8px;border-radius:4px;margin:0 auto;width:90%;}
.zone{position:absolute;inset:0;opacity:0;transition:opacity .2s;display:flex;align-items:center;justify-content:center;}
.zone.on{opacity:1;}
.zone-label{font-size:5px;color:#fff;font-weight:700;background:rgba(0,0,0,0.3);padding:2px 4px;border-radius:3px;}
.k-img-placeholder{display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.08);}
.k-img-placeholder svg{opacity:.3;}
.opts-hd{padding:24px 60px 18px 24px;flex-shrink:0;display:flex;align-items:center;gap:8px;}
.tab-opts-col.wide .opts-hd{padding-left:60px;}
.opts-hd-title{font-size:20px;font-weight:600;color:#111;white-space:nowrap;flex:1;}
.opts-body{flex:1;overflow-y:auto;scrollbar-width:none;}
.opts-sec{border-bottom:1px solid #F0EFE9;}
.opts-sec-hd{display:flex;align-items:center;justify-content:space-between;padding:26px 24px;cursor:pointer;user-select:none;touch-action:manipulation;width:100%;background:none;border:none;font:inherit;text-align:left;}
.opts-sec-title{font-size:17px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:.08em;}
.opts-sec-arr{font-size:16px;color:#ccc;transition:transform .18s;}
.opts-sec-arr.open{transform:rotate(90deg);}
.opts-sec-body{padding:0 24px 28px;display:flex;flex-direction:column;gap:12px;}
.sub-hd{display:flex;align-items:center;gap:12px;padding:20px 60px 20px 22px;flex-shrink:0;}
.tab-opts-col.wide .sub-hd{padding-left:60px;}
.sub-back{background:none;border:none;cursor:pointer;color:#F97316;font-size:28px;line-height:1;padding:0;outline:none;flex-shrink:0;touch-action:manipulation;}
.sub-title{font-size:18px;font-weight:600;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sub-body{flex:1;overflow-y:auto;scrollbar-width:none;padding:20px 24px;display:flex;flex-direction:column;gap:20px;}

/* ── TOGGLES ── */
.tog{display:flex;align-items:center;justify-content:space-between;padding:4px 0;}
.ttrack{width:52px;height:30px;border-radius:15px;background:rgba(0,0,0,0.10);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;touch-action:manipulation;padding:0;border:none;appearance:none;-webkit-appearance:none;}
.ttrack.on{background:#34C759;}
.tthumb{position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:4px;left:4px;transition:left .18s;box-shadow:0 1px 4px rgba(0,0,0,0.18);}
.ttrack.on .tthumb{left:26px;}
.tname{font-size:15px;color:#333;line-height:1.2;}
.tsub{font-size:12px;color:#bbb;margin-top:3px;}

/* ── INPUTS ── */
.inp{font-family:'Inter',sans-serif;font-size:15px;padding:12px 14px;border:1px solid rgba(0,0,0,0.09);border-radius:10px;background:#FAFAF8;color:#111;width:100%;}
.inp-num{font-family:'Inter',sans-serif;font-size:15px;padding:10px 12px;border:1px solid rgba(0,0,0,0.09);border-radius:10px;background:#FAFAF8;color:#111;width:90px;text-align:center;}
.inp-unit{font-size:13px;color:#999;}
.lang-kbd-btn{width:48px;height:48px;border-radius:10px;border:1px solid rgba(0,0,0,0.12);background:#F9F8F5;cursor:pointer;color:#555;flex-shrink:0;display:flex;align-items:center;justify-content:center;touch-action:manipulation;}
.lang-kbd-btn:hover{background:#F0EFEA;color:#111;}

/* ── PRODUCT IMAGE PLACEHOLDER ── */
.k-product-img,.k-product-img-1,.k-product-img-2,.k-product-img-3,.k-product-img-4{background-color:transparent;background-size:cover;background-position:center;background-repeat:no-repeat;}
.k-product-img,.k-product-img-1{background-image:url('/_content/Aisance.CarreWebComponents/defaults/burger1.png');}
.k-product-img-2{background-image:url('/_content/Aisance.CarreWebComponents/defaults/burger2.png');}
.k-product-img-3{background-image:url('/_content/Aisance.CarreWebComponents/defaults/burger3.png');}
.k-product-img-4{background-image:url('/_content/Aisance.CarreWebComponents/defaults/burger4.png');}

/* ── KIOSK TAB OPTS ── */
.kiosk-tab-opts .info-group{font-size:12px;}

/* ── EDIT ROWS ── */
.edit-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;}
.edit-label{font-size:18px;color:#333;line-height:1.3;}

/* ── TOGGLE SWITCH ── */
.toggle-sw{display:inline-flex;align-items:center;cursor:pointer;user-select:none;}
.toggle-sw input{display:none;}
.toggle-sw-track{position:relative;width:44px;height:24px;background:#D1D5DB;border-radius:12px;transition:background .2s;}
.toggle-sw input:checked~.toggle-sw-track{background:#22C55E;}
.toggle-sw-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.25);}
.toggle-sw input:checked~.toggle-sw-track .toggle-sw-thumb{left:23px;}
.edit-sub{font-size:14px;color:#bbb;margin-top:3px;}
.edit-btn{font-size:18px;color:#F97316;background:none;border:none;cursor:pointer;padding:14px 20px;border-radius:10px;flex-shrink:0;outline:none;touch-action:manipulation;}
.edit-btn:hover{background:rgba(249,115,22,0.08);}

/* ── PROPERTY FIELDS ── */
.pf{display:flex;flex-direction:column;gap:6px;}
.pf-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#bbb;}
.pf-row{display:flex;align-items:center;gap:12px;}
.pf-group{display:flex;flex-direction:column;gap:20px;}
.pf-group-title{font-size:18px;font-weight:600;color:#444;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,0.07);}

/* ── COLOR PICKER ── */
.color-pick{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid rgba(0,0,0,0.09);border-radius:10px;background:#FAFAF8;}
.color-swatch{width:34px;height:34px;border-radius:7px;border:1px solid rgba(0,0,0,0.10);flex-shrink:0;cursor:pointer;position:relative;overflow:hidden;}
.color-swatch input[type=color]{position:absolute;inset:-4px;width:calc(100% + 8px);height:calc(100% + 8px);opacity:0;cursor:pointer;border:none;padding:0;}
.color-hex{font-size:13px;color:#555;font-family:'SF Mono',monospace;flex:1;}

/* ── ENTRY VIEWS (cfg-*) ── */
.cfg-entry-row{display:flex;align-items:center;gap:10px;padding:10px 0;}
.cfg-entry-preview{display:flex;align-items:center;gap:12px;flex:1;min-width:0;}
.cfg-swatch{width:36px;height:36px;border-radius:8px;flex-shrink:0;}
.cfg-img-thumb{width:48px;height:36px;object-fit:cover;border-radius:8px;border:1px solid rgba(0,0,0,0.09);flex-shrink:0;}
.cfg-img-empty{display:flex;align-items:center;justify-content:center;background:#F4F3EF;}
.cfg-entry-info{display:flex;flex-direction:column;gap:2px;min-width:0;}
.cfg-entry-title{font-size:15px;font-weight:600;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cfg-entry-sub{font-size:12px;color:#9CA3AF;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cfg-adv-btn{background:none;border:none;font-size:26px;color:#F97316;cursor:pointer;padding:6px 10px;border-radius:8px;flex-shrink:0;line-height:1;touch-action:manipulation;}
.cfg-adv-btn:hover{background:rgba(249,115,22,0.08);}
.cfg-reset-btn{background:none;border:none;font-size:16px;color:#9CA3AF;cursor:pointer;padding:6px 8px;border-radius:8px;flex-shrink:0;touch-action:manipulation;}
.cfg-reset-btn:hover{color:#EF4444;}
.cfg-text-input{flex:1;padding:10px 12px;border:1px solid rgba(0,0,0,0.09);border-radius:10px;background:#FAFAF8;color:#111;font-family:'Inter',sans-serif;font-size:15px;outline:none;width:100%;}
.cfg-text-input:focus{border-color:#6366F1;box-shadow:0 0 0 3px rgba(99,102,241,0.1);}
.cfg-icon-btn{width:38px;height:38px;border-radius:9px;border:1px solid rgba(0,0,0,0.10);background:#F9F8F5;cursor:pointer;color:#555;display:flex;align-items:center;justify-content:center;touch-action:manipulation;}
.cfg-icon-btn:hover{background:#F0EFEA;color:#111;}

/* ── UPSELL PAGE PICKER ── */
.upsell-page-picker{margin-top:10px;padding:12px 14px;background:#F7F6F2;border-radius:12px;border:1px solid rgba(0,0,0,0.07);}
.upsell-chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;}
.upsell-chip{font-family:'Inter',sans-serif;font-size:13px;font-weight:500;padding:7px 14px;border-radius:20px;border:1.5px solid rgba(0,0,0,0.10);background:#fff;color:#555;cursor:pointer;transition:all .15s;touch-action:manipulation;white-space:nowrap;}
.upsell-chip:hover{border-color:rgba(249,115,22,0.4);color:#F97316;background:rgba(249,115,22,0.04);}
.upsell-chip.active{background:#F97316;border-color:#F97316;color:#fff;box-shadow:0 2px 8px rgba(249,115,22,0.25);}
.upsell-empty-hint{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:#888;line-height:1.5;padding:4px 0;}
.upsell-empty-hint strong{color:#555;}

/* ── SIDEBAR OVERLAY (hidden by default on desktop) ── */
.sb-overlay{display:none;}

/* ── LARGE SCREENS (≥1400px) — dialogs plus larges ── */
@media (min-width: 1400px) {
    .dlg-box{max-width:min(900px, 70vw);}
    .entry-dlg-box{max-width:min(760px, 65vw);}
    .blazor-dialog-box{max-width:min(1080px, 70vw);}
}

/* ── MOBILE (≤768px) ── */
@media (max-width: 768px) {
    .koc-app{font-size:13px;}
    .sidebar{position:fixed;top:0;left:0;bottom:0;z-index:100;box-shadow:4px 0 24px rgba(0,0,0,0.3);}
    .sidebar.closed{width:0;min-width:0;box-shadow:none;}
    .sb-item{padding:10px 10px;font-size:13px;gap:8px;}
    .sb-icon{width:15px;height:15px;}
    .sb-group-label{font-size:9px;padding:0 8px 6px;}
    .sb-top{padding:16px 14px 12px;}
    .sb-logo{font-size:14px;}
    .sb-bottom{padding:12px;}
    .sb-btn-reset{font-size:12px;padding:10px;}
    .tab-preview-col{display:none !important;}
    .tab-opts-col,.tab-opts-col.open{width:100% !important;flex:1;}
    .tab-opts-col.wide.open{width:100% !important;}
    .opts-hd{padding:16px 50px 14px 16px;}
    .opts-hd-title{font-size:16px;}
    .opts-sec-hd{padding:18px 16px;}
    .opts-sec-title{font-size:14px;}
    .opts-sec-body{padding:0 16px 20px;gap:10px;}
    .sub-hd{padding:14px 50px 14px 16px;}
    .sub-title{font-size:16px;}
    .sub-body{padding:14px 16px;gap:16px;}
    .edit-row{padding:12px 0;}
    .edit-label{font-size:15px;}
    .edit-btn{font-size:16px;padding:10px 14px;}
    .pf-label{font-size:10px;}
    .pf-group-title{font-size:15px;}
    .inp,.cfg-text-input{font-size:14px;padding:10px 12px;}
    .inp-num{font-size:14px;padding:8px 10px;width:80px;}
    .tog{padding:2px 0;}
    .tname{font-size:14px;}
    .tsub{font-size:11px;}
    .ttrack{width:46px;height:26px;}
    .tthumb{width:20px;height:20px;top:3px;left:3px;}
    .ttrack.on .tthumb{left:23px;}
    .cfg-entry-title{font-size:14px;}
    .cfg-entry-sub{font-size:11px;}
    .pv-btn{width:36px;height:36px;border-radius:8px;}
    .pv-btn-sb{top:10px;left:10px;}
    .pv-btn-opts{display:none !important;}
    .sb-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:99;}
    .sb-overlay.hidden{display:none;}
    .opts-hd{padding-left:56px;}
    .tab-opts-col.wide .opts-hd{padding-left:56px;}
    .sub-hd{padding-left:56px;}
    .tab-opts-col.wide .sub-hd{padding-left:56px;}
    .palette-grid{grid-template-columns:repeat(2, 1fr) !important;}
    .dlg-overlay{padding:8px;}
    .dlg-box{border-radius:14px;max-height:85vh;}
    .dlg-header{padding:12px 12px 6px;}
    .dlg-title{font-size:16px;}
    .dlg-kicker{font-size:10px;}
    .dlg-body{padding:6px 12px 12px;gap:8px;}
    .dlg-card{padding:12px;gap:10px;border-radius:12px;}
    .valid-btn{min-height:44px;font-size:14px;border-radius:12px;}
    .cancel-btn{min-height:44px;font-size:14px;border-radius:12px;}
    .blazor-dialog-overlay{padding:8px !important;}
    .blazor-dialog-box{max-width:95vw !important;max-height:85vh !important;border-radius:14px !important;}
    .zone-pick{padding:12px 10px;font-size:14px;}
    .pad-card{padding:6px !important;}
    .kb-key{min-width:0 !important;min-height:34px !important;max-width:none !important;font-size:14px !important;border-radius:5px !important;padding:0 !important;flex:1 !important;}
    .kb-key--wide{flex:3 !important;}
    .kb-key--secondary{flex:1.5 !important;font-size:12px !important;}
    .kb-row{gap:3px !important;}
    .keyboard{gap:4px !important;}
    .entry-display{font-size:18px !important;}
    .entry-dlg-box{max-width:95vw !important;}
    .display-card{padding:8px 10px !important;gap:8px !important;}
    .entry-backspace{width:34px !important;height:34px !important;}
    .two-col{grid-template-columns:1fr !important;}
    .lang-kbd-btn{width:42px !important;height:42px !important;border-radius:10px !important;}
    .lang-input{font-size:14px !important;padding:10px 12px !important;}
    .lang-card-label{font-size:12px;width:24px;}
    .ai-overlay{padding:8px !important;}
    .ai-panel{max-width:95vw !important;border-radius:14px !important;}
    .ai-textarea{min-height:80px;font-size:12px;}
}
