@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --bg:#080810; --surface:#111120; --surface2:#1a1a2e; --border:#2e2e4a;
  --accent:#f97316; --accent-dim:rgba(249,115,22,0.13); --accent-glow:rgba(249,115,22,0.35);
  --text:#eeeeff; --text-dim:#7777aa; --text-muted:#444466;
  --red:#ef4444; --green:#22c55e; --blue:#3b82f6;
  --fh:'Barlow Condensed',sans-serif; --fb:'DM Sans',sans-serif;
  --topbar-h:70px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);font-family:var(--fb);color:var(--text);-webkit-font-smoothing:antialiased;user-select:none}
button{font-family:var(--fb);cursor:pointer;border:none;outline:none;background:none;color:inherit}
input,select,textarea{font-family:var(--fb)}
::-webkit-scrollbar{width:4px} ::-webkit-scrollbar-track{background:var(--surface)} ::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}

@keyframes fadeUp  {from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn  {from{opacity:0}to{opacity:1}}
@keyframes float   {0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes spinSlow{to{transform:rotate(360deg)}}
@keyframes glow    {0%,100%{box-shadow:0 0 22px var(--accent-glow)}50%{box-shadow:0 0 55px rgba(249,115,22,.7)}}
@keyframes idleBg  {0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes bounceIn{0%{transform:scale(.3);opacity:0}55%{transform:scale(1.08)}80%{transform:scale(.97)}100%{transform:scale(1);opacity:1}}
@keyframes slideUp {from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes spin    {to{transform:rotate(360deg)}}
@keyframes countUp {from{transform:scale(1.5);color:var(--accent)}to{transform:scale(1)}}
@keyframes checkPop{0%{transform:scale(0) rotate(-30deg);opacity:0}60%{transform:scale(1.15) rotate(5deg)}100%{transform:scale(1) rotate(0);opacity:1}}

/* APP SHELL */
#app{width:100vw;height:100vh;display:flex;flex-direction:column}
.hidden{display:none!important}

/* IDLE */
#idle-screen{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(-45deg,#080810,#111120,#180830,#081820);background-size:400% 400%;animation:idleBg 10s ease infinite;cursor:pointer;overflow:hidden}
#idle-screen.hidden{display:none}
.idle-ring{position:absolute;border-radius:50%;border:1px solid rgba(249,115,22,.06);top:50%;left:50%;transform:translate(-50%,-50%)}
.idle-glow{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(249,115,22,.18) 0%,transparent 70%);filter:blur(40px);width:320px;height:320px;top:28%;left:50%;transform:translate(-50%,-50%)}
.idle-logo{animation:float 4.5s ease-in-out infinite;text-align:center;z-index:1;margin-bottom:12px}
.idle-emoji{font-size:110px;line-height:1;filter:drop-shadow(0 0 40px rgba(249,115,22,.55));display:block;margin-bottom:8px}
.idle-title{font-family:var(--fh);font-size:72px;font-weight:900;line-height:.9;letter-spacing:-2px;background:linear-gradient(135deg,#f97316,#fb923c,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}
.idle-sub{color:var(--text-dim);font-family:var(--fh);font-size:22px;font-weight:600;letter-spacing:8px}
.idle-clock{text-align:center;z-index:1;margin:32px 0}
.idle-time{font-family:var(--fh);font-size:80px;font-weight:900;letter-spacing:-2px;line-height:1}
.idle-date{color:var(--text-dim);font-size:17px;margin-top:6px}
.idle-cta{z-index:1;animation:glow 2.8s ease-in-out infinite;border-radius:100px}
.idle-cta-btn{background:var(--accent);color:#fff;font-family:var(--fh);font-size:24px;font-weight:800;letter-spacing:2px;padding:22px 80px;border-radius:100px;text-transform:uppercase;display:block}
.idle-footer{position:absolute;bottom:28px;z-index:1;color:var(--text-muted);font-size:13px}
#admin-zone{position:fixed;bottom:0;right:0;width:80px;height:80px;z-index:200}

/* TOPBAR */
#topbar{height:var(--topbar-h);flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:14px}
.tb-home{color:var(--text-dim);font-size:28px;padding:6px 10px;border-radius:8px;transition:color .2s}
.tb-home:hover{color:var(--text)}
.tb-back{background:var(--surface2);color:var(--text);border:1px solid var(--border);padding:9px 18px;border-radius:10px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:border-color .2s}
.tb-back:hover{border-color:var(--accent)}
.tb-steps{flex:1;display:flex;align-items:center;justify-content:center;gap:6px}
.tb-step{display:flex;align-items:center;gap:6px}
.tb-step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:13px;font-weight:800;background:var(--border);color:var(--text-dim);transition:all .3s}
.tb-step-num.active{background:var(--accent);color:#fff;box-shadow:0 0 16px var(--accent-glow)}
.tb-step-num.done{background:var(--accent);color:#fff}
.tb-step-label{font-size:12px;color:var(--text-dim);transition:color .2s}
.tb-step-label.active{color:var(--text);font-weight:600}
.tb-step-sep{width:20px;height:1px;background:var(--border);transition:background .3s}
.tb-step-sep.done{background:var(--accent)}
.tb-cart{background:var(--surface2);border:1px solid var(--border);padding:10px 20px;border-radius:14px;display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;transition:all .25s;cursor:pointer}
.tb-cart.has-items{background:var(--accent);border-color:var(--accent);color:#fff}
.tb-cart-icon{font-size:20px}
.tb-cart-count{font-family:var(--fh);font-size:20px;font-weight:800}
.tb-cart-sep{opacity:.6}

/* MAIN */
#main{flex:1;overflow:hidden;display:flex;flex-direction:column;position:relative}
.screen{position:absolute;inset:0;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:opacity .25s;align-items:center;justify-content:center}
.screen.active{opacity:1;pointer-events:all}
.screen-head{padding:28px 36px 0;flex-shrink:0;align-self:stretch}
.screen-head h2{font-family:var(--fh);font-size:42px;font-weight:900;letter-spacing:-.5px;margin-bottom:6px}
.screen-head p{color:var(--text-dim);font-size:16px}
.scroll-area{flex:1;overflow-y:auto;padding:24px 36px 36px;width:100%}

/* CATEGORIES */
#screen-categories{align-items:stretch;justify-content:flex-start}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cat-card{background:var(--surface);border:2px solid var(--border);border-radius:22px;padding:32px 20px;text-align:center;cursor:pointer;transition:all .22s;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center}
.cat-card:hover{transform:translateY(-6px)}
.cat-card-bar{position:absolute;top:0;left:0;right:0;height:4px;border-radius:22px 22px 0 0;opacity:.8}
.cat-card-emoji{font-size:60px;margin-bottom:14px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}
.cat-card-name{font-family:var(--fh);font-size:22px;font-weight:800;margin-bottom:6px}
.cat-card-count{color:var(--text-dim);font-size:13px}
.cat-card:nth-child(1){animation:fadeUp .4s ease 0s both}
.cat-card:nth-child(2){animation:fadeUp .4s ease .06s both}
.cat-card:nth-child(3){animation:fadeUp .4s ease .12s both}
.cat-card:nth-child(4){animation:fadeUp .4s ease .18s both}
.cat-card:nth-child(5){animation:fadeUp .4s ease .24s both}
.cat-card:nth-child(6){animation:fadeUp .4s ease .30s both}

/* PRODUCTS */
#screen-products{align-items:stretch;justify-content:flex-start}
.cat-tabs{padding:10px 28px 0;display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}
.cat-tab{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:9px 18px;border-radius:100px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .18s}
.cat-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
#prod-head{padding:20px 28px 14px;flex-shrink:0}
#prod-head h3{font-family:var(--fh);font-size:30px;font-weight:800;margin-bottom:4px}
#prod-head p{color:var(--text-dim);font-size:14px}
.prod-grid-wrap{flex:1;overflow-y:auto;padding:0 28px 28px;width:100%}
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.prod-card{background:var(--surface);border:2px solid var(--border);border-radius:18px;padding:22px;cursor:pointer;transition:all .2s;position:relative}
.prod-card:hover{transform:translateY(-3px);border-color:var(--accent)}
.prod-card.in-cart{border-color:var(--accent)}
.prod-card-badge{position:absolute;top:14px;right:14px;background:var(--accent);color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:14px;font-weight:800}
.prod-card-name{font-family:var(--fh);font-size:20px;font-weight:800;margin-bottom:8px}
.prod-card-meta{color:var(--text-dim);font-size:12px;margin-bottom:14px;min-height:16px}
.prod-card-footer{display:flex;align-items:center;justify-content:space-between}
.prod-price{font-family:var(--fh);font-size:26px;font-weight:900;color:var(--accent)}
.prod-add-btn{background:var(--accent-dim);color:var(--accent);padding:7px 16px;border-radius:100px;font-size:13px;font-weight:600;transition:background .15s}
.prod-card:hover .prod-add-btn{background:var(--accent);color:#fff}

/* MODAL */
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .18s ease}
#modal-box{background:var(--surface);border-radius:24px;padding:40px;width:530px;max-height:88vh;overflow-y:auto;border:1px solid var(--border);box-shadow:0 48px 96px rgba(0,0,0,.6);animation:bounceIn .3s ease}
.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.modal-title{font-family:var(--fh);font-size:28px;font-weight:900;margin-bottom:6px}
.modal-price{font-family:var(--fh);font-size:34px;font-weight:900;color:var(--accent)}
.modal-close{background:var(--surface2);color:var(--text-dim);width:44px;height:44px;border-radius:50%;font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.modal-section-label{font-size:11px;color:var(--text-dim);font-weight:700;letter-spacing:1.4px;text-transform:uppercase;margin-bottom:10px}
.variants-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}
.variant-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:10px 20px;border-radius:100px;font-size:14px;cursor:pointer;transition:all .15s}
.variant-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.nota-area{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px;color:var(--text);font-size:14px;resize:none;height:90px;outline:none;transition:border-color .2s;margin-bottom:22px}
.nota-area:focus{border-color:var(--accent)}
.qty-row{display:flex;align-items:center;margin-bottom:28px}
.qty-label{font-size:11px;color:var(--text-dim);font-weight:700;letter-spacing:1.4px;text-transform:uppercase}
.qty-controls{display:flex;align-items:center;gap:14px;margin-left:auto}
.qty-btn{width:48px;height:48px;border-radius:50%;font-size:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s}
.qty-btn:active{transform:scale(.9)}
.qty-btn-minus{background:var(--surface2);border:1px solid var(--border)}
.qty-btn-plus{background:var(--accent);color:#fff}
.qty-value{font-family:var(--fh);font-size:34px;font-weight:900;min-width:36px;text-align:center}
.modal-confirm{width:100%;background:var(--accent);color:#fff;padding:18px;border-radius:14px;font-size:19px;font-weight:700;font-family:var(--fh);display:flex;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:transform .1s;border:none}
.modal-confirm:active{transform:scale(.98)}

/* CART */
#screen-cart{flex-direction:row;align-items:stretch;justify-content:flex-start}
.cart-list-wrap{flex:1;overflow-y:auto;padding:28px 28px 28px 36px}
.cart-list-wrap h2{font-family:var(--fh);font-size:38px;font-weight:900;margin-bottom:22px}
.cart-items{display:flex;flex-direction:column;gap:12px}
.cart-item{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:18px 20px;display:flex;align-items:center;gap:16px;animation:fadeUp .3s ease}
.cart-item-info{flex:1}
.cart-item-name{font-family:var(--fh);font-size:19px;font-weight:800;margin-bottom:4px}
.cart-item-variant{font-size:13px;color:var(--accent);margin-bottom:2px}
.cart-item-nota{font-size:12px;color:var(--text-dim)}
.cart-item-unit{color:var(--text-dim);font-size:13px;margin-top:4px}
.cart-item-qty{display:flex;align-items:center;gap:10px}
.ci-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:transform .1s;border:none}
.ci-btn:active{transform:scale(.88)}
.ci-minus{background:var(--surface2);border:1px solid var(--border)!important}
.ci-plus{background:var(--accent);color:#fff}
.ci-qty{font-family:var(--fh);font-size:22px;font-weight:800;min-width:24px;text-align:center}
.cart-item-price{font-family:var(--fh);font-size:20px;font-weight:900;color:var(--accent);min-width:80px;text-align:right}
.ci-del{width:36px;height:36px;border-radius:50%;background:rgba(239,68,68,.14);border:1px solid rgba(239,68,68,.3)!important;color:var(--red);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px}
.cart-empty-icon{font-size:90px}
.cart-empty h3{font-family:var(--fh);font-size:32px;font-weight:800;color:var(--text-dim)}
.cart-empty-btn{background:var(--accent);color:#fff;padding:14px 32px;border-radius:12px;font-size:17px;font-weight:600;cursor:pointer;margin-top:8px;border:none}
.cart-summary{width:310px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);padding:32px 28px;display:flex;flex-direction:column}
.cart-summary h3{font-family:var(--fh);font-size:26px;font-weight:900;margin-bottom:22px}
.cart-summary-lines{flex:1;overflow-y:auto;margin-bottom:16px}
.csl{display:flex;justify-content:space-between;margin-bottom:10px;font-size:14px}
.csl span:first-child{color:var(--text-dim)}
.csl span:last-child{font-weight:600}
.cart-total-row{border-top:1px solid var(--border);padding-top:18px;display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.cart-total-label{font-family:var(--fh);font-size:20px;font-weight:800}
.cart-total-val{font-family:var(--fh);font-size:34px;font-weight:900;color:var(--accent)}
.btn-primary{width:100%;background:var(--accent);color:#fff;padding:18px;border-radius:14px;font-size:19px;font-weight:700;font-family:var(--fh);cursor:pointer;transition:transform .1s;display:flex;align-items:center;justify-content:center;gap:8px;border:none}
.btn-primary:active{transform:scale(.98)}
.btn-secondary{width:100%;margin-top:10px;background:var(--surface2);color:var(--text-dim);border:1px solid var(--border);padding:14px;border-radius:12px;font-size:15px;cursor:pointer}

/* CUSTOMER */
#screen-customer{align-items:stretch;justify-content:flex-start}
#screen-customer .scroll-area{display:flex;gap:36px}
.customer-form{flex:1}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
.form-full{grid-column:1/-1}
.field{margin-bottom:18px}
.field label{display:block;font-size:11px;font-weight:700;color:var(--text-dim);margin-bottom:9px;letter-spacing:1.2px;text-transform:uppercase}
.field input,.field select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;color:var(--text);font-size:15px;outline:none;transition:border-color .2s}
.field input:focus,.field select:focus{border-color:var(--accent)}
.field.error input,.field.error select{border-color:var(--red)}
.field-error{color:var(--red);font-size:12px;margin-top:5px}
.consenso-box{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;gap:14px;align-items:flex-start;margin-top:4px}
.consenso-box input[type="checkbox"]{width:20px;height:20px;flex-shrink:0;margin-top:2px;accent-color:var(--accent);cursor:pointer}
.consenso-box label{font-size:14px;color:var(--text-dim);line-height:1.5;cursor:pointer}
.customer-side{width:270px;flex-shrink:0}
.customer-side-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px;text-align:center;position:sticky;top:0}
.customer-side-icon{font-size:52px;margin-bottom:12px}
.customer-side-hint{color:var(--text-dim);font-size:13px;line-height:1.5;margin-bottom:18px}
.cust-total-label{color:var(--text-dim);font-size:13px;margin-bottom:4px}
.cust-total-val{font-family:var(--fh);font-size:34px;font-weight:900;color:var(--accent);margin-bottom:4px}
.cust-total-note{color:var(--text-muted);font-size:12px;margin-bottom:20px}
.cust-divider{border:none;border-top:1px solid var(--border);margin-bottom:20px}

/* CONFIRM */
#screen-confirm{align-items:stretch;justify-content:flex-start}
#screen-confirm .scroll-area{display:flex;gap:32px}
.confirm-left{flex:1;display:flex;flex-direction:column;gap:16px}
.confirm-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:22px}
.confirm-section h4{font-family:var(--fh);font-size:17px;font-weight:800;color:var(--accent);margin-bottom:14px}
.cdata-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px;font-size:15px}
.cdata-row .lbl{color:var(--text-dim);font-size:13px}
.conf-item{padding:10px 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start}
.conf-item:last-child{border-bottom:none}
.conf-item-name{font-weight:600}
.conf-item-var{color:var(--accent);font-size:13px}
.conf-item-nota{font-size:12px;color:var(--text-dim)}
.conf-item-right{text-align:right;flex-shrink:0;margin-left:16px}
.conf-item-price{font-weight:700}
.conf-item-qty{font-size:12px;color:var(--text-dim)}
.conf-total-row{border-top:2px solid var(--accent);padding-top:14px;margin-top:4px;display:flex;justify-content:space-between;align-items:center}
.conf-total-label{font-family:var(--fh);font-size:20px;font-weight:900}
.conf-total-val{font-family:var(--fh);font-size:30px;font-weight:900;color:var(--accent)}
.confirm-right{width:278px;flex-shrink:0}
.confirm-right-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px;text-align:center;position:sticky;top:0}
.confirm-right-icon{font-size:52px;margin-bottom:12px}
.confirm-right-hint{color:var(--text-dim);font-size:13px;line-height:1.6;margin-bottom:24px}
.spinner{width:22px;height:22px;border-radius:50%;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;animation:spin 1s linear infinite;display:inline-block}

/* SUCCESS */
#screen-success{padding:36px 40px;overflow-y:auto;gap:0}
.success-check{font-size:88px;animation:checkPop .55s ease;margin-bottom:18px}
.success-title{font-family:var(--fh);font-size:46px;font-weight:900;margin-bottom:10px;text-align:center}
.success-sub{color:var(--text-dim);font-size:17px;max-width:440px;text-align:center;margin-bottom:32px}
.success-qr-box{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:36px;display:flex;flex-direction:column;align-items:center;gap:18px;box-shadow:0 28px 64px rgba(0,0,0,.45);margin-bottom:28px}
.success-qr-hint{color:var(--text-dim);font-size:15px;font-weight:600}
#qr-img{width:220px;height:220px;border-radius:14px;border:4px solid var(--accent);box-shadow:0 0 44px var(--accent-glow)}
.success-order-id{font-family:var(--fh);font-size:40px;font-weight:900;color:var(--accent);letter-spacing:5px}
.success-order-meta{color:var(--text-dim);font-size:14px;margin-top:4px}
.success-countdown{color:var(--text-dim);font-size:14px}
.success-countdown strong{color:var(--accent)}

/* ERROR */
#screen-error{gap:16px}
.err-icon{font-size:80px}
.err-title{font-family:var(--fh);font-size:32px;font-weight:900;color:var(--red)}
.err-msg{color:var(--text-dim);max-width:400px;text-align:center}
.err-btns{display:flex;gap:12px;margin-top:8px}
.err-retry{background:var(--accent);color:#fff;padding:14px 30px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;border:none}
.err-home{background:var(--surface2);color:var(--text);border:1px solid var(--border);padding:14px 30px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer}

/* LOADING */
#screen-loading{gap:16px}
.loading-spinner{width:56px;height:56px;border-radius:50%;border:4px solid var(--border);border-top-color:var(--accent);animation:spin 1s linear infinite}

/* ADMIN */
#admin-panel{position:fixed;inset:0;background:var(--bg);z-index:900;display:flex;flex-direction:column;animation:slideUp .3s ease}
.admin-topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:18px 32px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.admin-topbar-titles{flex:1}
.admin-topbar h1{font-family:var(--fh);font-size:28px;font-weight:900}
.admin-topbar p{color:var(--text-dim);font-size:13px}
.admin-filter{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:9px 14px;color:var(--text);font-size:14px}
.admin-link{background:var(--blue);color:#fff;padding:9px 16px;border-radius:10px;font-size:13px;font-weight:600}
.admin-close{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:9px 18px;border-radius:10px;font-size:14px;cursor:pointer}
.admin-stats{padding:20px 32px 0;display:flex;gap:14px}
.admin-stat{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px 24px;flex:1}
.admin-stat-label{color:var(--text-dim);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.admin-stat-val{font-family:var(--fh);font-size:38px;font-weight:900}
.admin-table-wrap{flex:1;overflow:auto;padding:24px 32px}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{padding:11px 14px;text-align:left;color:var(--text-dim);font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;border-bottom:2px solid var(--border)}
.admin-table td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:top}
.admin-table tr:hover td{background:var(--surface)}
.admin-oid{font-family:var(--fh);color:var(--accent);font-weight:800;font-size:15px}
.admin-tag{background:var(--accent-dim);color:var(--accent);padding:2px 8px;border-radius:100px;font-size:12px;margin:2px;display:inline-block}
.admin-badge-yes{background:rgba(34,197,94,.14);color:var(--green);padding:3px 10px;border-radius:100px;font-size:12px;font-weight:700}
.admin-badge-no{background:rgba(239,68,68,.14);color:var(--red);padding:3px 10px;border-radius:100px;font-size:12px;font-weight:700}
.admin-empty{text-align:center;padding:60px;color:var(--text-dim)}

/* TOAST */
#toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--border);padding:14px 24px;border-radius:100px;font-size:15px;font-weight:500;z-index:999;box-shadow:0 8px 30px rgba(0,0,0,.4);transition:opacity .3s;white-space:nowrap;animation:fadeUp .3s ease}
#toast.hidden{opacity:0;pointer-events:none}

/* LOADING OVERLAY */
#loading-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:800;display:flex;align-items:center;justify-content:center}
.loading-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px 60px;display:flex;flex-direction:column;align-items:center;gap:18px}
.loading-box p{color:var(--text-dim);font-size:15px}
/* ── ALLERGIE ── */
.prod-card-allergie{display:flex;flex-wrap:wrap;gap:4px;padding:4px 0 2px;line-height:1}
.allerg-icon{font-size:18px;cursor:default;transition:transform .15s}
.allerg-icon:hover{transform:scale(1.25)}
.modal-allergie-wrap{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0 4px}
.modal-allergie-wrap.hidden{display:none}
.modal-allerg-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.25);border-radius:100px;padding:4px 11px;font-size:13px;color:var(--text-dim)}
.modal-allerg-chip span{font-size:12px;text-transform:capitalize}

/* ── ASPORTO CHOICE ── */
.asporto-choice{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.asporto-opt{padding:14px 10px;border-radius:14px;border:2px solid var(--border);background:var(--surface2);color:var(--text-dim);font-size:15px;font-weight:600;cursor:pointer;transition:all .18s;text-align:center;line-height:1.3}
.asporto-opt.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}
#asporto-costo-hint{font-size:13px;color:var(--accent);font-weight:600;margin-top:6px;min-height:18px}
.csl-extra{opacity:.8;font-style:italic}

/* ── STEPPER COPERTI ── */
.stepper-wrap{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--surface2);width:fit-content;min-width:180px}
.stepper-btn{width:56px;height:56px;font-size:26px;font-weight:300;border:none;background:transparent;color:var(--text);cursor:pointer;transition:background .15s;flex-shrink:0;display:flex;align-items:center;justify-content:center;user-select:none}
.stepper-btn:active{background:var(--accent-dim)}
.stepper-minus{border-right:1px solid var(--border)}
.stepper-plus{border-left:1px solid var(--border)}
.stepper-val{flex:1;text-align:center;font-family:var(--fh);font-size:26px;font-weight:800;color:var(--text);user-select:none}

/* ── TASTIERA DISPLAY FIELD ── */
.kb-display{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;min-height:52px;display:flex;align-items:center;gap:2px;transition:border-color .2s}
.kb-display:hover,.kb-display:focus{border-color:var(--accent)}
.kb-display-text{font-size:15px;color:var(--text-dim);flex:1}
.kb-display-text.kb-has-value{color:var(--text)}
.kb-cursor{font-size:18px;color:var(--accent);animation:kb-blink 1s step-end infinite}
@keyframes kb-blink{0%,100%{opacity:1}50%{opacity:0}}

/* ── TASTIERA OVERLAY ── */
.kb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:9000;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.kb-overlay.hidden{display:none}
.kb-modal{width:100%;max-width:700px;background:var(--surface);border-radius:24px 24px 0 0;padding:20px 16px 24px;box-shadow:0 -8px 40px rgba(0,0,0,.4)}
.kb-preview{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 18px;font-size:20px;font-weight:600;color:var(--text);margin-bottom:16px;min-height:52px;display:flex;align-items:center;gap:3px;letter-spacing:.3px}
.kb-cursor-blink{color:var(--accent);animation:kb-blink 1s step-end infinite;font-weight:300}
.kb-rows{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.kb-row{display:flex;justify-content:center;gap:6px}
.kb-key{height:52px;min-width:48px;padding:0 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:17px;font-weight:600;cursor:pointer;transition:background .1s,transform .08s;flex:1;max-width:64px}
.kb-key:active{background:var(--accent-dim);transform:scale(.92)}
.kb-bottom-row{display:flex;gap:8px;margin-top:4px}
.kb-space{flex:3;height:52px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text-dim);font-size:14px;font-weight:600;cursor:pointer}
.kb-backspace{flex:2;height:52px;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:20px;cursor:pointer}
.kb-done{flex:2;height:52px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-size:15px;font-weight:700;cursor:pointer}
.kb-backspace:active,.kb-space:active{background:var(--surface3)}
.kb-done:active{opacity:.85}

/* ── TASTIERA: titolo e shortcuts ── */
.kb-modal-title{font-family:var(--fh);font-size:16px;font-weight:800;color:var(--text-dim);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}
.kb-shortcuts{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.kb-shortcut{padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:background .1s}
.kb-shortcut:active{background:var(--accent-dim)}

/* Aggiungi/modifica questi stili nella sezione PRODOTTI GRID */
.prod-btn{
  display:flex;flex-direction:column;justify-content:flex-start;gap:5px;
  background:var(--surface);border:1.5px solid var(--border);border-radius:14px;
  padding:14px 16px;cursor:pointer;transition:all .15s;text-align:left;
  width:100%;
}
.prod-btn img{width:100%;height:100%;object-fit:cover;border-radius:12px}
