.bookshelf-overlay{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9999;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:2rem 1rem}.bookshelf-container{position:relative;width:95vw;max-width:1400px;background:linear-gradient(180deg,#3a2a1a,#2d1f12);border:6px solid #1a1a2e;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.8),inset 0 0 40px rgba(0,0,0,.5);margin:auto;animation:bookshelfSlideIn .5s ease-out}@keyframes bookshelfSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.bookshelf-close{position:absolute;top:1rem;right:1rem;z-index:10;width:48px;height:48px;background:#ff6b6b;color:#fff;border:4px solid #1a1a2e;cursor:pointer;transition:all .2s ease;box-shadow:4px 4px 0 rgba(0,0,0,.3)}.bookshelf-close:hover{background:#ff5252;transform:scale(1.1)}.bookshelf-header{background:linear-gradient(135deg,#5a3a2a,#4a2a1a);border-bottom:4px solid #1a1a2e;padding:2rem;text-align:center;box-shadow:inset 0 -4px 8px rgba(0,0,0,.3)}.bookshelf-title{margin:0 0 .5rem;color:gold;text-shadow:2px 2px 0 #1a1a2e,0 0 20px rgba(255,215,0,.5)}.bookshelf-subtitle{color:#4ecdc4;margin:0}.bookshelf-body{display:grid;grid-template-columns:1fr 400px;gap:2rem;padding:2rem}.bookshelf-shelves{background:repeating-linear-gradient(90deg,rgba(92,51,23,.5),rgba(92,51,23,.5) 2px,transparent 0,transparent 4px),linear-gradient(180deg,#5c3317,#4a2912);border:4px solid #2d1810;border-radius:12px;padding:2rem;box-shadow:inset 0 4px 12px rgba(0,0,0,.5),inset 0 0 40px rgba(0,0,0,.3);min-height:400px;position:relative}.bookshelf-shelves:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(180deg,transparent,transparent 150px,rgba(0,0,0,.3) 0,rgba(0,0,0,.3) 154px,rgba(139,90,43,.1) 0,rgba(139,90,43,.1) 160px);pointer-events:none;border-radius:8px}.shelf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:2rem;position:relative;z-index:1}.shelf-slot{position:relative;transition:transform .3s ease}.shelf-slot.selected{transform:translateY(-8px)}.shelf-slot.selected:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-bottom:12px solid #4ecdc4;filter:drop-shadow(0 0 8px rgba(78,205,196,.6));animation:bounce .5s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-4px)}}.empty-shelf{text-align:center;padding:4rem 2rem;color:#8b5a2b}.bookshelf-info-panel{background:rgba(26,26,46,.9);border:4px solid #4ecdc4;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 0 30px rgba(78,205,196,.3),inset 0 0 20px rgba(0,0,0,.5)}.info-display{background:#1a1a2e;border:3px solid #4ecdc4;border-radius:8px;padding:1rem;min-height:60px;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 8px rgba(0,0,0,.5),0 0 15px rgba(78,205,196,.2)}.digital-text{color:#4ecdc4;text-align:center;line-height:1.6;text-shadow:0 0 10px rgba(78,205,196,.8);animation:textGlow 2s ease-in-out infinite}@keyframes textGlow{0%,to{opacity:1}50%{opacity:.8}}.browse-instructions{text-align:center;color:#4ecdc4;opacity:.7}.bookshelf-actions{display:flex;flex-direction:column;gap:.75rem}.bookshelf-actions .action-button{width:100%;padding:1rem;text-transform:uppercase;letter-spacing:1px}.bookshelf-cart-section{background:rgba(26,26,46,.95);border:3px solid #4ecdc4;border-radius:8px;padding:1rem;max-height:300px;overflow-y:auto;box-shadow:inset 0 2px 8px rgba(0,0,0,.5)}.bookshelf-cart-section::-webkit-scrollbar{width:8px}.bookshelf-cart-section::-webkit-scrollbar-track{background:#1a1a2e;border-radius:4px}.bookshelf-cart-section::-webkit-scrollbar-thumb{background:#4ecdc4;border-radius:4px}.bookshelf-cart-section::-webkit-scrollbar-thumb:hover{background:#3dbbb3}.cart-total-bookshelf{margin-top:1rem;padding-top:1rem;border-top:2px solid #4ecdc4;text-align:center;color:#4ecdc4}.bookshelf-checkout{width:100%;padding:1.5rem;background:linear-gradient(135deg,#4ecdc4,#3dbbb3);border:none;border-top:4px solid #1a1a2e;border-radius:0 0 12px 12px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.bookshelf-checkout:disabled{opacity:.5;cursor:not-allowed}.bookshelf-checkout:not(:disabled):hover{background:linear-gradient(135deg,#5eddd5,#4ecdc4);box-shadow:0 -4px 20px rgba(78,205,196,.5)}.bookshelf-checkout:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.3),transparent);transition:left .5s ease}.bookshelf-checkout:hover:before{left:100%}.checkout-label{color:#1a1a2e;font-weight:700;position:relative;z-index:1}.bookshelf-button{position:absolute;top:240px;right:50px;z-index:100;background:transparent;border:none;padding:0;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem;box-shadow:0 8px 32px rgba(139,90,43,.5);animation:pulse 2s ease-in-out infinite}.bookshelf-button:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 40px rgba(139,90,43,.7),0 0 30px rgba(255,215,0,.4)}.bookshelf-icon{width:100px;height:100px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5a2b,#5c3317);border:4px solid #4a2912;border-radius:12px;box-shadow:inset 0 2px 8px rgba(0,0,0,.5),0 4px 12px rgba(0,0,0,.3);filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.bookshelf-tag{color:#8b5a2b;background:rgba(26,26,46,.9);border:3px solid #8b5a2b;border-radius:6px;padding:.25rem .5rem;text-transform:uppercase;letter-spacing:1px;box-shadow:0 0 10px rgba(139,90,43,.5)}@media (max-width:1200px){.bookshelf-body{grid-template-columns:1fr}.bookshelf-info-panel{order:-1}}@media (max-width:768px){.bookshelf-container{width:98vw}.shelf-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.bookshelf-button{top:180px;right:30px}.bookshelf-icon{width:80px;height:80px}}.snail-mascot-wrapper{position:fixed;top:10rem;left:2rem;z-index:150}.display-case-2d{position:relative;width:160px;height:180px;margin:0 auto}.case-back-wall{position:absolute;top:0;left:10px;width:140px;height:140px;background:linear-gradient(180deg,#2d1b3d,#1a1a2e);border:3px solid #4ecdc4;border-radius:12px 12px 0 0;box-shadow:inset 0 0 30px rgba(78,205,196,.2),0 4px 20px rgba(0,0,0,.5);z-index:1}.case-ambient-glow{top:20px;left:50%;width:100px;height:100px;background:radial-gradient(circle at center,rgba(78,205,196,.3) 0,rgba(255,215,0,.1) 40%,transparent 70%);border-radius:50%;filter:blur(20px);z-index:2;pointer-events:none}.case-ambient-glow,.case-pedestal{position:absolute;transform:translateX(-50%)}.case-pedestal{bottom:50px;height:20px;background:linear-gradient(180deg,#3d2a4d,#2d1b3d);border:2px solid rgba(78,205,196,.6);border-radius:6px;box-shadow:0 4px 8px rgba(0,0,0,.4),inset 0 2px 6px rgba(78,205,196,.3);z-index:3}.case-pedestal,.snail-sprite{left:calc(50% - 45px);width:90px}.snail-sprite{position:absolute;bottom:65px;transform:translateX(-50%);height:90px;z-index:10;cursor:pointer}.snail-image{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 6px 12px rgba(0,0,0,.5));image-rendering:crisp-edges}.case-glass-overlay{position:absolute;top:0;left:10px;width:140px;height:140px;background:linear-gradient(135deg,rgba(78,205,196,.15),rgba(78,205,196,.03) 50%,rgba(78,205,196,.2));border:3px solid rgba(78,205,196,.5);border-radius:12px 12px 0 0;box-shadow:inset 0 0 40px rgba(78,205,196,.1),0 8px 32px rgba(78,205,196,.2);backdrop-filter:blur(2px);z-index:5;pointer-events:none}.case-bottom{position:absolute;bottom:30px;left:0;width:160px;height:30px;background:linear-gradient(180deg,#2d1b3d,#1a1a2e);border:3px solid #4ecdc4;border-radius:0 0 16px 16px;box-shadow:0 8px 24px rgba(0,0,0,.6),inset 0 4px 12px rgba(78,205,196,.2);z-index:11}.speech-bubble-2d{position:absolute;top:-10px;left:155px;background:rgba(45,27,61,.95);border:3px solid #4ecdc4;border-radius:12px;padding:8px 6px;min-width:280px;max-width:400px;box-shadow:0 8px 24px rgba(0,0,0,.4),0 0 20px rgba(78,205,196,.3);z-index:12}.speech-text{line-height:1.5;text-align:center;color:#f5f5f5;text-shadow:2px 2px 0 rgba(0,0,0,.5)}.speech-tail{left:-15px;top:50%;transform:translateY(-50%);border-top:12px solid transparent;border-bottom:12px solid transparent;border-right:15px solid #4ecdc4}.speech-tail,.speech-tail:after{position:absolute;width:0;height:0}.speech-tail:after{content:"";left:4px;top:-9px;border-top:9px solid transparent;border-bottom:9px solid transparent;border-right:12px solid rgba(45,27,61,.95)}.case-label-2d{position:absolute;bottom:0;left:50%;transform:translateX(-50%);background:rgba(26,26,46,.95);border:2px solid #4ecdc4;border-radius:8px;padding:.35rem 1rem;color:#4ecdc4;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.4),0 0 10px rgba(78,205,196,.4);letter-spacing:1px}@media (max-width:768px){.display-case-2d,.snail-mascot-wrapper,.speech-bubble-2d{display:none}}@media (max-width:480px){.display-case-2d,.snail-mascot-wrapper{display:none}}.vending-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:2rem;animation:fadeIn .3s ease-out;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(78,205,196,.5) rgba(10,10,26,.8)}@media (max-width:768px){.vending-overlay{padding:15px;align-items:stretch}}.vending-machine{position:relative;width:900px;max-width:95vw;display:flex;flex-direction:column;animation:machineSlideIn .5s cubic-bezier(.34,1.56,.64,1);margin:auto}@keyframes machineSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.vending-close{position:absolute;top:-15px;right:-15px;z-index:210;width:40px;height:40px;padding:0;border-radius:50%;background:#ff6b9d;border:3px solid #1a1a2e;box-shadow:0 4px 12px rgba(255,107,157,.5)}.vending-close:hover{background:#ff4081;transform:scale(1.1) rotate(90deg)}.vending-header{margin-bottom:-10px;z-index:3;display:flex;justify-content:center}.vending-sign{background:linear-gradient(135deg,#ff6b9d,gold);color:#1a1a2e;padding:.75rem 3rem;border:4px solid #1a1a2e;border-radius:12px 12px 0 0;font-weight:700;letter-spacing:3px;box-shadow:0 -4px 0 #1a1a2e,inset 0 2px 0 hsla(0,0%,100%,.3),0 0 30px rgba(255,215,0,.4);text-shadow:2px 2px 0 rgba(0,0,0,.2)}.vending-body{background:linear-gradient(135deg,#2d3561,#1a1a2e);border:6px solid #1a1a2e;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.8),inset 0 2px 0 rgba(78,205,196,.2),0 0 40px rgba(78,205,196,.2);overflow:hidden;display:flex;flex-direction:column;position:relative}.vending-body:before{left:0;background:linear-gradient(90deg,rgba(0,0,0,.3),transparent)}.vending-body:after,.vending-body:before{content:"";position:absolute;top:0;bottom:0;width:30px;z-index:1}.vending-body:after{right:0;background:linear-gradient(270deg,rgba(0,0,0,.3),transparent)}.vending-glass{position:relative;background:linear-gradient(135deg,rgba(10,10,26,.9),rgba(26,26,46,.95));border:8px solid #0a0a1a;border-radius:12px;margin:1.5rem;min-height:400px;box-shadow:inset 0 0 40px rgba(0,0,0,.6),inset 0 4px 0 rgba(78,205,196,.1),0 8px 32px rgba(0,0,0,.5)}.glass-shine{top:0;left:0;right:0;height:100px;background:linear-gradient(180deg,rgba(78,205,196,.15),transparent)}.glass-reflection,.glass-shine{position:absolute;pointer-events:none;z-index:2}.glass-reflection{top:20%;left:10%;width:30%;height:40%;background:linear-gradient(135deg,hsla(0,0%,100%,.05),transparent 50%);border-radius:50%;filter:blur(20px);animation:reflectionShimmer 4s ease-in-out infinite}@keyframes reflectionShimmer{0%,to{opacity:.3}50%{opacity:.6}}.vending-products-display{padding:2rem;position:relative;z-index:1}.vending-shelves{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1.5rem}.vending-slot{position:relative;background:rgba(26,26,46,.6);border:3px solid rgba(78,205,196,.3);border-radius:8px;padding:.5rem;transition:all .3s ease}.vending-slot:hover{border-color:#4ecdc4;box-shadow:0 0 20px rgba(78,205,196,.4);transform:translateY(-4px)}.vending-slot.selected{border-color:gold;box-shadow:0 0 30px rgba(255,215,0,.6),inset 0 0 20px rgba(255,215,0,.2);animation:selectedPulse 1.5s ease-in-out infinite}@keyframes selectedPulse{0%,to{box-shadow:0 0 30px rgba(255,215,0,.6),inset 0 0 20px rgba(255,215,0,.2)}50%{box-shadow:0 0 40px rgba(255,215,0,.8),inset 0 0 30px rgba(255,215,0,.3)}}.sold-out-sign{text-align:center;padding:4rem 2rem;color:#ff6b9d;text-transform:uppercase;letter-spacing:4px;animation:soldOutBlink 1.5s ease-in-out infinite}.sold-out-sub{color:hsla(0,0%,96%,.6);margin-top:1rem;letter-spacing:2px}@keyframes soldOutBlink{0%,to{opacity:1}50%{opacity:.5}}.vending-controls{background:linear-gradient(180deg,#1a1a2e,#0a0a1a);border-top:4px solid #0a0a1a;padding:1.5rem}.control-panel{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}.vending-display{grid-column:1/-1;background:#0a0a1a;border:4px solid #2d1b3d;border-radius:8px;padding:.5rem;box-shadow:inset 0 2px 8px rgba(0,0,0,.6)}.display-screen{background:linear-gradient(180deg,#1a3a2e,#0f2419);color:#4ecdc4;padding:.75rem 1rem;border-radius:4px;text-align:center;letter-spacing:2px;box-shadow:inset 0 2px 4px rgba(0,0,0,.5),0 0 20px rgba(78,205,196,.3);animation:displayGlow 2s ease-in-out infinite}@keyframes displayGlow{0%,to{text-shadow:0 0 10px rgba(78,205,196,.8)}50%{text-shadow:0 0 20px #4ecdc4}}.vending-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.keypad-button{background:linear-gradient(135deg,#2d1b3d,#1a1a2e);border:3px solid #4ecdc4;border-radius:6px;padding:.75rem;color:#4ecdc4;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 0 #1a1a2e}.keypad-button:hover{background:linear-gradient(135deg,#3d2a4d,#2d1b3d);transform:translateY(-2px);box-shadow:0 6px 0 #1a1a2e,0 0 15px rgba(78,205,196,.4)}.keypad-button:active{transform:translateY(2px);box-shadow:0 2px 0 #1a1a2e}.keypad-button:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.quantity-controls{background:linear-gradient(135deg,#2d1b3d,#1a1a2e);border:3px solid gold;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:inset 0 2px 4px rgba(0,0,0,.4),0 0 20px rgba(255,215,0,.3)}.quantity-label{color:gold;text-align:center;letter-spacing:2px}.quantity-display{color:gold;text-align:center;background:rgba(10,10,26,.8);border:2px solid gold;border-radius:6px;padding:.5rem;box-shadow:inset 0 2px 4px rgba(0,0,0,.5),0 0 15px rgba(255,215,0,.4);text-shadow:0 0 10px rgba(255,215,0,.8)}.quantity-buttons{display:flex;gap:.5rem}.qty-button{flex:1;background:linear-gradient(135deg,#4ecdc4,#3a9d96);border:3px solid #2d8a84;border-radius:6px;padding:.75rem;color:#1a1a2e;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 0 #2d8a84}.qty-button:hover:not(:disabled){background:linear-gradient(135deg,#5eddd6,#4ab3ac);transform:translateY(-2px);box-shadow:0 6px 0 #2d8a84,0 0 15px rgba(78,205,196,.5)}.qty-button:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px 0 #2d8a84}.qty-button:disabled{opacity:.4;cursor:not-allowed}.vending-actions{display:flex;flex-direction:column;gap:.5rem}.action-button{background:linear-gradient(135deg,#4ecdc4,#3a9d96);border:3px solid #2d8a84;border-radius:6px;padding:.75rem 1rem;color:#1a1a2e;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 0 #2d8a84;letter-spacing:1px}.action-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 0 #2d8a84,0 0 15px rgba(78,205,196,.5)}.action-button:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px 0 #2d8a84}.action-button:disabled{opacity:.5;cursor:not-allowed}.details-button{background:linear-gradient(135deg,gold,#ffb700);border-color:#d9a000;box-shadow:0 4px 0 #d9a000;color:#1a1a2e}.details-button:hover:not(:disabled){box-shadow:0 6px 0 #d9a000,0 0 15px rgba(255,215,0,.5)}.details-button:active:not(:disabled){box-shadow:0 2px 0 #d9a000}.add-to-cart-button{background:linear-gradient(135deg,#4ecdc4,#3a9d96)}.cancel-button{background:linear-gradient(135deg,#ff6b9d,#d9557f);border-color:#b34569;box-shadow:0 4px 0 #b34569}.cancel-button:hover:not(:disabled){box-shadow:0 6px 0 #b34569,0 0 15px rgba(255,107,157,.5)}.cancel-button:active:not(:disabled){box-shadow:0 2px 0 #b34569}.coin-slot,.payment-slots{display:flex;flex-direction:column;gap:.5rem}.coin-slot{background:linear-gradient(135deg,#2d1b3d,#1a1a2e);border:3px solid #4ecdc4;border-radius:8px;padding:.75rem;box-shadow:inset 0 2px 4px rgba(0,0,0,.4)}.slot-label-small{color:#4ecdc4;text-align:center;letter-spacing:1px}.slot-opening{height:40px;background:#0a0a1a;border:2px solid #2d1b3d;border-radius:4px;box-shadow:inset 0 2px 8px rgba(0,0,0,.8);position:relative}.slot-opening:after{content:"";position:absolute;top:50%;left:10%;right:10%;height:3px;background:linear-gradient(90deg,transparent,#4ecdc4 50%,transparent);transform:translateY(-50%);opacity:.3}.vending-cart-section{background:linear-gradient(180deg,#0a0a1a,#1a1a2e);border-top:4px solid #0a0a1a;padding:1rem 1.5rem;box-shadow:inset 0 4px 8px rgba(0,0,0,.5)}.cart-header{color:#4ecdc4;letter-spacing:2px;text-align:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid rgba(78,205,196,.3)}.cart-items-container{min-height:100px}.cart-empty,.cart-loading{text-align:center;padding:2rem;color:hsla(0,0%,96%,.5)}.cart-items-list{display:flex;flex-direction:column;gap:.75rem}.cart-item{display:grid;grid-template-columns:50px 1fr auto auto auto;gap:.75rem;align-items:center;background:rgba(26,26,46,.6);border:2px solid rgba(78,205,196,.3);border-radius:8px;padding:.75rem;transition:all .3s ease}.cart-item:hover{border-color:#4ecdc4;box-shadow:0 0 15px rgba(78,205,196,.3)}.cart-item-image{width:50px;height:50px;border-radius:6px;overflow:hidden;background:rgba(10,10,26,.8);border:2px solid rgba(78,205,196,.2)}.cart-thumbnail{width:100%;height:100%;object-fit:cover}.cart-item-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.cart-item-name{color:#f5f5f5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-item-price{color:hsla(0,0%,96%,.6)}.cart-item-quantity{display:flex;align-items:center;gap:.5rem;background:rgba(10,10,26,.8);border:2px solid rgba(78,205,196,.3);border-radius:6px;padding:.25rem .5rem}.cart-qty-btn{background:linear-gradient(135deg,#2d1b3d,#1a1a2e);border:2px solid #4ecdc4;border-radius:4px;padding:.25rem .75rem;min-width:80px;width:auto;color:#4ecdc4;cursor:pointer;transition:all .2s ease;height:34px;display:flex;align-items:center;justify-content:center;font-size:10px}.cart-qty-btn:hover:not(:disabled){background:linear-gradient(135deg,#3d2a4d,#2d1b3d);box-shadow:0 0 10px rgba(78,205,196,.4)}.cart-qty-btn:disabled{opacity:.3;cursor:not-allowed}.cart-qty-display{color:#4ecdc4;min-width:20px;text-align:center}.cart-item-total{color:gold;font-weight:700;min-width:60px;text-align:right}.cart-item-remove{background:linear-gradient(135deg,#ff6b9d,#d9557f);border:2px solid #b34569;border-radius:4px;padding:.25rem .5rem;color:#1a1a2e;cursor:pointer;transition:all .2s ease;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center}.cart-item-remove:hover{background:linear-gradient(135deg,#ff4081,#c94569);box-shadow:0 0 10px rgba(255,107,157,.5);transform:scale(1.1)}.cart-total-section{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:2px solid rgba(78,205,196,.3)}.cart-total-label{color:#4ecdc4;letter-spacing:2px}.cart-total-amount{color:gold;font-weight:700;text-shadow:0 0 10px rgba(255,215,0,.6)}.vending-overlay::-webkit-scrollbar{width:12px}.vending-overlay::-webkit-scrollbar-track{background:rgba(10,10,26,.8)}.vending-overlay::-webkit-scrollbar-thumb{background:rgba(78,205,196,.5);border-radius:6px}.vending-overlay::-webkit-scrollbar-thumb:hover{background:rgba(78,205,196,.7)}.vending-dispenser{background:linear-gradient(180deg,#1a1a2e,#0a0a1a);border:none;border-top:4px solid #0a0a1a;padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:inset 0 4px 8px rgba(0,0,0,.5);cursor:pointer;transition:all .3s ease;width:100%;position:relative}.vending-dispenser:hover{background:linear-gradient(180deg,#2d1b3d,#1a1a2e);box-shadow:inset 0 4px 8px rgba(0,0,0,.5),0 0 30px rgba(78,205,196,.4)}.vending-dispenser:hover .dispenser-flap{border-color:#4ecdc4;box-shadow:inset 0 4px 0 rgba(78,205,196,.3),inset 0 -4px 8px rgba(0,0,0,.6),0 0 20px rgba(78,205,196,.3)}.vending-dispenser:hover .dispenser-label{color:gold;border-color:gold;box-shadow:0 0 15px rgba(255,215,0,.5)}.vending-dispenser:active{transform:translateY(2px)}.dispenser-flap{flex:1;height:60px;background:linear-gradient(180deg,#2d1b3d,#1a1a2e);border:4px solid #0a0a1a;border-radius:8px;box-shadow:inset 0 4px 0 rgba(78,205,196,.2),inset 0 -4px 8px rgba(0,0,0,.6);position:relative;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.flap-icon{text-shadow:0 0 10px rgba(78,205,196,.6)}.dispenser-flap:after{content:"";position:absolute;bottom:0;left:0;right:0;height:8px;background:linear-gradient(90deg,transparent,rgba(78,205,196,.3) 50%,transparent)}.dispenser-label{background:rgba(26,26,46,.9);color:#4ecdc4;border:2px solid #4ecdc4;border-radius:6px;padding:.5rem 1rem;letter-spacing:2px;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.3)}.vending-base{height:20px;background:linear-gradient(180deg,#0a0a1a,#000);border:4px solid #000;border-top:none;border-radius:0 0 12px 12px;box-shadow:0 8px 32px rgba(0,0,0,.9)}@media (max-width:768px){.vending-machine{width:100%;max-width:100%;height:100%}.vending-sign{padding:.5rem 2rem;letter-spacing:2px}.vending-glass{min-height:300px}.vending-shelves{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.control-panel{grid-template-columns:1fr}.vending-keypad{grid-template-columns:repeat(3,1fr)}.keypad-button{padding:.5rem}.quantity-controls{padding:.75rem}.quantity-display{padding:.375rem}.qty-button{padding:.5rem}.action-button{padding:.5rem .75rem}.cart-item{grid-template-columns:40px 1fr auto auto;gap:.5rem;padding:.5rem}.cart-item-image{width:40px;height:40px}.cart-item-total{display:none}.cart-qty-btn{min-width:70px;height:auto;padding:.2rem .5rem;font-size:9px}.cart-item-remove{min-width:20px;height:20px}}@media (max-width:480px){.vending-overlay{padding:1rem}.vending-machine{max-width:100%}.vending-body{margin:0}.vending-glass{margin:1rem;min-height:250px}.vending-products-display{padding:1rem}.vending-shelves{grid-template-columns:repeat(2,1fr);gap:.75rem}.sold-out-sign{padding:3rem 1rem}.vending-cart-section{padding:.75rem}.cart-header{margin-bottom:.75rem}.cart-item{grid-template-columns:35px 1fr auto;gap:.5rem;padding:.5rem}.cart-item-image{width:35px;height:35px}.cart-item-price,.cart-item-total{display:none}.cart-item-quantity{padding:.2rem .4rem;gap:.4rem}}