@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg: #181a1b;--header-bg: #23272a;--card-bg: #23272a;--card-shadow: 0 2px 16px rgba(0,0,0,.3);--text-main: #f3f4f6;--text-muted: #b0b3b8;--text-light: #aaa;--product-bg: #23272a;--review-bg: #181a1b;--payment-available: #4ade80;--payment-unavailable: #f87171;--star: #fbbf24;--vending-machine-bg: linear-gradient(145deg, #e6e6e6, #ffffff);--vending-machine-border: #d0d0d0;--product-grid-bg: linear-gradient(145deg, #f8f9fa, #e9ecef);--product-grid-border: #dee2e6;--product-grid-bg-hover: linear-gradient(145deg, #f3f4f6, #e5e7eb)}html[data-theme=dark]{--bg: #181a1b;--header-bg: #23272a;--card-bg: #23272a;--card-shadow: 0 2px 16px rgba(0,0,0,.3);--text-main: #f3f4f6;--text-muted: #b0b3b8;--text-light: #aaa;--product-bg: #23272a;--review-bg: #181a1b;--payment-available: #4ade80;--payment-unavailable: #f87171;--star: #fbbf24;--vending-machine-bg: linear-gradient(145deg, #2d2d2d, #1a1a1a);--vending-machine-border: #404040;--product-grid-bg: linear-gradient(145deg, #3a3a3a, #2a2a2a);--product-grid-border: #505050;--product-grid-bg-hover: linear-gradient(145deg, #4a4a4a, #3a3a3a)}html[data-theme=light]{--bg: #f6f8fa;--header-bg: #fff;--card-bg: #fff;--card-shadow: 0 2px 16px rgba(0,0,0,.07);--text-main: #222;--text-muted: #666;--text-light: #888;--product-bg: #f3f4f6;--review-bg: #f9fafb;--payment-available: #16a34a;--payment-unavailable: #ef4444;--star: #f59e42}*{box-sizing:border-box}html,body,#root{height:100%;min-height:100vh;margin:0;padding:0;width:100%}body{font-family:Inter,sans-serif;background:var(--bg);margin:0;padding:0;color:var(--text-main);min-height:100vh;width:100%}.header{text-align:center;padding:3rem 0 2rem;background:var(--header-bg);box-shadow:0 2px 8px #00000008;margin:0;width:100%;position:relative}.header-content,.main-content{max-width:1200px;margin:0 auto;padding:0 2rem}.machine-card{background:var(--card-bg);border-radius:0;box-shadow:none;margin:0;padding:2.5rem 0;width:100%;display:flex;flex-direction:column;gap:1.5rem}.machine-header{display:flex;align-items:center;gap:1.5rem;padding:0 1rem}.machine-photo{width:120px;height:120px;object-fit:cover;border-radius:12px;box-shadow:0 1px 6px #00000014;background:#eee}.machine-info{flex:1}.machine-content{padding:0 1rem}.products-list{display:flex;flex-wrap:wrap;gap:1rem;margin:0;padding:0;list-style:none}.product-item{background:var(--product-bg);border-radius:8px;padding:.5rem 1rem;min-width:120px;display:flex;flex-direction:column;align-items:flex-start}.payment-methods{display:flex;gap:1rem;margin-top:.5rem}.payment-icon{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-weight:500;font-size:1rem;width:100%}.payment-text{color:inherit}.payment-logo{height:1.4em;width:auto;vertical-align:middle;margin-right:.5rem;display:inline-block}.payment-status{width:12px;height:12px;border-radius:50%;border:2px solid currentColor;flex-shrink:0}.payment-status.available{background-color:#22c55e;border-color:#22c55e}.payment-status.unavailable{background-color:#ef4444;border-color:#ef4444}.payment-methods-header .payment-icon{font-size:.9rem;justify-content:space-between}.reviews-list{margin:.5rem 0 0;padding:0;list-style:none}.review-item{background:var(--review-bg);border-radius:6px;padding:.5rem 1rem;margin-bottom:.5rem;font-size:.98rem}h1,h2,h3,h4,h5,h6{color:var(--text-main)}.machine-info>div{color:var(--text-muted)}.header p{color:var(--text-light)!important}.review-item b{color:var(--star)!important}.dark-toggle{display:flex;gap:.5rem;position:absolute;top:20px;right:20px}.dark-toggle button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.2rem .5rem;border-radius:6px;transition:background .15s;color:var(--text-main);opacity:.7;outline:none}.dark-toggle button:focus{outline:none}.dark-toggle button.active,.dark-toggle button:hover{background:var(--product-bg);opacity:1}html[data-theme=dark] .dark-toggle button.active,html[data-theme=dark] .dark-toggle button:hover{background:#ffffff26;opacity:1}html[data-theme=light] .dark-toggle button.active,html[data-theme=light] .dark-toggle button:hover{background:var(--product-bg);opacity:1}.home-button{position:absolute;top:20px;left:20px;font-size:1.8rem;text-decoration:none;color:var(--text-main);opacity:.8;transition:opacity .2s,transform .2s;padding:.25rem;border-radius:6px;display:flex;align-items:center;justify-content:center}.home-button:hover{opacity:1;transform:scale(1.1);background:var(--product-bg)}.vending-machine{background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:12px;padding:1.5rem;margin:1rem 0;box-shadow:0 8px 24px #0000004d;border:3px solid #7f8c8d}html[data-theme=light] .vending-machine{background:linear-gradient(135deg,#ecf0f1,#bdc3c7);border:3px solid #95a5a6;box-shadow:0 8px 24px #00000026}.vending-machine-header{text-align:left;margin-bottom:1rem;padding:1rem;background:#0000004d;border-radius:8px;color:#ecf0f1}html[data-theme=light] .vending-machine-header{background:#fffc;color:#2c3e50}.machine-info-header{display:flex;align-items:flex-start;gap:1rem;justify-content:space-between}.machine-photo-header{width:120px;height:120px;display:flex;align-items:center;justify-content:center;background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 1px 6px #00000014}.machine-photo-header img{width:100%;height:100%;object-fit:cover;border-radius:12px}.machine-photo-header img[src*=blob]{max-width:100%;max-height:100%;object-fit:contain}.gallery{margin:2rem 0}.gallery h3{margin:0 0 1rem;font-size:1.1rem}.gallery-scroll{display:flex;gap:1rem;overflow-x:auto;padding:.5rem 0;scroll-behavior:smooth}.gallery-scroll::-webkit-scrollbar{height:6px}.gallery-scroll::-webkit-scrollbar-track{background:var(--product-bg);border-radius:3px}.gallery-scroll::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}.gallery-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-main)}.gallery-photo{min-width:150px;height:100px;object-fit:cover;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 8px #0000001a}.gallery-photo:hover{transform:scale(1.05);box-shadow:0 4px 16px #0003}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}.modal-content{position:relative;max-width:90vw;max-height:90vh;background:var(--card-bg);border-radius:12px;padding:1rem;box-shadow:0 8px 32px #0000004d}.modal-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.modal-close{position:absolute;top:-10px;right:-10px;width:40px;height:40px;border:none;background:#ef4444;color:#fff;border-radius:50%;font-size:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;transition:background .2s}.modal-close:hover{background:#dc2626}.owner-logo-header{width:60px;height:60px;object-fit:cover;border-radius:8px;box-shadow:0 2px 8px #0003;background:#eee}.machine-details{flex:1}.payment-methods-header{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end;min-width:150px;flex-shrink:0;margin-left:auto;width:100%;max-width:200px}.payment-methods-header>div{width:100%;display:flex;align-items:center;justify-content:flex-end}.vending-machine-display{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(5,1fr);gap:.3rem;background:#0003;padding:.8rem;border-radius:8px;min-height:240px}html[data-theme=light] .vending-machine-display{background:#ffffff80}.vending-slot{background:linear-gradient(145deg,#34495e,#2c3e50);border:2px solid #7f8c8d;border-radius:8px;padding:.05rem;display:flex;flex-direction:column;align-items:center;position:relative;min-height:35px;transition:transform .2s,box-shadow .2s}.vending-slot:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}html[data-theme=light] .vending-slot{background:linear-gradient(145deg,#ecf0f1,#bdc3c7);border:2px solid #95a5a6}.slot-code{position:absolute;top:4px;left:6px;background:#e74c3c;color:#fff;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:1px}.slot-product{display:flex;flex-direction:column;align-items:center;text-align:center;height:100%;justify-content:space-between}.product-image{width:22px;height:22px;margin-bottom:.03rem;display:flex;align-items:center;justify-content:center}.product-image img{width:100%;height:100%;object-fit:cover;border-radius:4px}.product-placeholder{font-size:1.5rem;opacity:.7}.product-name{font-size:.7rem;font-weight:700;color:#ecf0f1;margin-bottom:.03rem;line-height:1.1}html[data-theme=light] .product-name{color:#2c3e50}.product-desc{font-size:.6rem;color:var(--text-muted);margin-top:.03rem}.product-price{font-size:.7rem;color:var(--payment-available);font-weight:500;margin-top:.03rem}html[data-theme=light] .product-desc{color:var(--text-muted)}.slot-empty{display:flex;align-items:center;justify-content:center;height:100%;opacity:.3}.empty-placeholder{font-size:.8rem;color:#7f8c8d;font-style:italic}.payment-emoji{margin-right:.5rem;display:inline-block;width:1.4em;text-align:center}.payment-logo{height:1.4em;width:1.4em;vertical-align:middle;margin-right:.5rem;display:inline-block;object-fit:contain}@media (max-width: 900px){.header-content,.main-content{padding:0 1rem}.machine-card{padding:2rem 0}.vending-machine-display{grid-template-columns:repeat(auto-fill,minmax(75px,1fr));gap:.25rem}.vending-slot{min-height:22px;padding:.03rem}.product-image{width:18px;height:18px}.product-name{font-size:.65rem}.product-desc{font-size:.55rem}}@media (max-width: 700px){.header{padding:1.5rem 0 1rem}.main-content{padding:0 .5rem}.machine-card{padding:1.5rem 0}.machine-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:0 .5rem}.machine-content{padding:0 .5rem}.machine-photo{width:100%;height:180px}.dark-toggle{right:10px;top:10px}.vending-machine-display{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(10,1fr);min-height:600px}}.login-page{min-height:100vh;display:flex;flex-direction:column}.login-container{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{background:var(--card-bg);border-radius:12px;padding:3rem;box-shadow:var(--card-shadow);width:100%;max-width:400px}.login-card h2{margin:0 0 2rem;text-align:center;color:var(--text-main)}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #fcc;text-align:center}html[data-theme=dark] .error-message{background:#422;color:#fcc;border-color:#633}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-main)}.form-group input{padding:.75rem;border:2px solid var(--product-bg);border-radius:6px;background:var(--bg);color:var(--text-main);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4ade80}.login-button{background:#4ade80;color:#fff;border:none;padding:.875rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;margin-top:.5rem}.login-button:hover:not(:disabled){background:#22c55e}.login-button:disabled{opacity:.6;cursor:not-allowed}.demo-credentials{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--product-bg)}.demo-credentials h4{margin:0 0 1rem;color:var(--text-muted);font-size:.9rem}.demo-credentials p{margin:.5rem 0;font-size:.85rem;color:var(--text-light);font-family:monospace}.admin-dashboard{min-height:100vh}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 1rem}.header-left,.header-right{display:flex;align-items:center;gap:1rem}.logout-button{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background .2s}.logout-button:hover{background:#dc2626}.dashboard-content{max-width:1200px;margin:0 auto;padding:2rem 1rem}.dashboard-actions{margin-bottom:2rem}.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:6px;text-decoration:none;font-weight:600;cursor:pointer;border:none;font-size:.9rem;transition:all .2s}.btn-primary{background:#4ade80;color:#fff}.btn-primary:hover{background:#22c55e;transform:translateY(-1px)}.btn-secondary{background:var(--product-bg);color:var(--text-main)}.btn-secondary:hover{background:var(--text-muted);color:var(--bg)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.machines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.machine-admin-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--card-shadow);transition:transform .2s,box-shadow .2s}.machine-admin-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000001a}html[data-theme=dark] .machine-admin-card:hover{box-shadow:0 8px 32px #0000004d}.machine-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem;gap:1rem}.machine-logo-section{flex-shrink:0}.machine-logo{width:60px;height:60px;border-radius:8px;object-fit:cover;border:2px solid var(--card-border)}.machine-logo-placeholder{width:60px;height:60px;border-radius:8px;background:var(--card-bg);border:2px solid var(--card-border);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-muted)}.machine-title-section{flex:1;min-width:0}.machine-header h3{margin:0 0 .5rem;color:var(--text-main);font-size:1.1rem;word-wrap:break-word}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#fee2e2;color:#991b1b}html[data-theme=dark] .status-badge.active{background:#166534;color:#dcfce7}html[data-theme=dark] .status-badge.inactive{background:#991b1b;color:#fee2e2}.machine-info{margin-bottom:1.5rem}.machine-info p{margin:.5rem 0;color:var(--text-muted);font-size:.9rem}.machine-actions{display:flex;gap:.75rem;flex-wrap:wrap}.machine-actions .btn{padding:.5rem 1rem;font-size:.85rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state h3{margin:0 0 1rem;color:var(--text-main)}.empty-state p{margin:0 0 2rem;font-size:1.1rem}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.header-left{justify-content:center}.login-card{padding:2rem}.machines-grid{grid-template-columns:1fr}.machine-actions{justify-content:center}.dashboard-content{padding:1rem}}@media (max-width: 480px){.machine-header{flex-direction:column;align-items:flex-start;gap:.5rem}.machine-actions .btn{flex:1;text-align:center}}.add-machine-page{min-height:100vh;background:var(--bg);color:var(--text-main)}.form-container{max-width:800px;margin:0 auto;padding:2rem}.machine-form{background:var(--card-bg);border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a}.form-section{margin-bottom:2.5rem}.form-section h2{margin:0 0 1.5rem;color:var(--text-main);font-size:1.4rem;font-weight:600;border-bottom:2px solid var(--text-muted);padding-bottom:.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0;border:none;padding:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-row.three-cols{grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:500;color:var(--text-main);font-size:.9rem}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border:1px solid var(--text-muted);border-radius:6px;font-size:1rem;transition:border-color .2s,box-shadow .2s;background:var(--bg);color:var(--text-main)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--payment-available);box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:.5rem;cursor:pointer;font-weight:400!important;margin-bottom:0!important}.checkbox-label input[type=checkbox]{width:auto;margin:0}.product-form{border:1px solid var(--text-muted);border-radius:8px;padding:1.5rem;margin-bottom:1rem;background:var(--product-bg)}.product-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.product-header h3{margin:0;color:var(--text-main);font-size:1.1rem;font-weight:600}.payment-methods-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.payment-method-item{padding:1rem;border:1px solid var(--text-muted);border-radius:8px;background:var(--product-bg)}.payment-method-name{font-weight:500}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--text-muted)}.form-actions-top{margin-top:0;margin-bottom:2rem;padding-top:0;padding-bottom:2rem;border-top:none;border-bottom:1px solid var(--text-muted)}.back-button{background:none;border:none;color:var(--text-main);font-size:1rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:background .2s}.back-button:hover{background:var(--product-bg)}html[data-theme=dark]{--input-background: #374151;--form-section-background: #1f2937}html[data-theme=light]{--input-background: #ffffff;--form-section-background: #f9fafb}@media (max-width: 768px){.form-container{padding:1rem}.machine-form{padding:1.5rem}.form-row,.form-row.three-cols{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.form-actions{flex-direction:column-reverse}.form-actions-top{flex-direction:column}.payment-methods-grid{grid-template-columns:1fr}.product-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 480px){.form-container{padding:.5rem}.machine-form{padding:1rem}}.file-upload{margin-bottom:1rem}.file-upload-area{border:2px dashed var(--text-muted);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--bg)}.file-upload-area:hover{border-color:var(--payment-available);background:var(--product-bg)}.file-upload-area.drag-over{border-color:var(--payment-available);background:#22c55e1a;transform:scale(1.02)}.file-upload-area.disabled{opacity:.6;cursor:not-allowed}.file-upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.file-upload-icon{font-size:3rem;opacity:.6}.file-upload-text{color:var(--text-main)}.file-upload-text strong{font-size:1.1rem;color:var(--payment-available)}.file-upload-info{font-size:.9rem;color:var(--text-muted);line-height:1.4}.file-upload-errors{margin-top:1rem}.gallery-manager,.gallery-upload{margin-bottom:2rem}.gallery-items h4{margin:0 0 1rem;color:var(--text-main);font-weight:600}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.gallery-item{border:1px solid var(--text-muted);border-radius:8px;overflow:hidden;background:var(--card-bg)}.gallery-preview-container{position:relative;aspect-ratio:16/9;overflow:hidden}.gallery-preview{width:100%;height:100%;object-fit:cover;display:block}.gallery-item-overlay{position:absolute;top:.5rem;right:.5rem;opacity:0;transition:opacity .2s ease}.gallery-item:hover .gallery-item-overlay{opacity:1}.btn.btn-sm{padding:.25rem .5rem;font-size:.8rem;border-radius:4px}.gallery-item-info{padding:1rem}.gallery-item-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.file-type-badge{display:inline-flex;align-items:center;gap:.25rem;background:var(--product-bg);padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;color:var(--text-main)}.file-size{font-size:.8rem;color:var(--text-muted)}.gallery-caption-input{width:100%;padding:.5rem;border:1px solid var(--text-muted);border-radius:4px;font-size:.9rem;background:var(--bg);color:var(--text-main);margin-bottom:.5rem}.gallery-caption-input:focus{outline:none;border-color:var(--payment-available);box-shadow:0 0 0 3px #22c55e1a}.original-name{font-size:.8rem;color:var(--text-muted);word-break:break-all}.gallery-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);background:var(--product-bg);border-radius:8px;border:1px solid var(--text-muted)}.logo-upload{margin-bottom:1rem}.logo-preview{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:1rem;background:var(--product-bg);border-radius:8px;border:1px solid var(--text-muted)}.logo-preview img{width:80px;height:80px;object-fit:cover;border-radius:8px;border:1px solid var(--text-muted)}.logo-preview-info{flex:1}.logo-preview-info h5{margin:0 0 .5rem;color:var(--text-main);font-size:1rem}.logo-preview-info p{margin:0;font-size:.9rem;color:var(--text-muted)}.logo-actions{display:flex;gap:.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-main);font-size:.9rem}.optional-text{font-weight:400;color:var(--text-muted);font-size:.8rem}.logo-help-text{margin-top:.5rem;font-size:.8rem;color:var(--text-muted);line-height:1.4}@media (max-width: 768px){.file-upload-area{padding:1.5rem 1rem}.file-upload-icon{font-size:2rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.gallery-item-info{padding:.75rem}.logo-preview{flex-direction:column;text-align:center}.logo-actions{justify-content:center}}@media (max-width: 480px){.gallery-grid{grid-template-columns:1fr}.file-upload-area{padding:1rem}}.modal-nav{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;color:#fff;border:none;border-radius:50%;width:50px;height:50px;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1001}.modal-nav:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.modal-nav-left{left:20px}.modal-nav-right{right:20px}.modal-counter{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;z-index:1001}@media (max-width: 768px){.modal-nav{width:40px;height:40px;font-size:20px}.modal-nav-left{left:10px}.modal-nav-right{right:10px}.modal-counter{bottom:10px;padding:6px 12px;font-size:12px}}@media (max-width: 768px){.machine-info-header{flex-direction:column;align-items:flex-start;gap:1rem}.machine-photo-header{width:80px;height:80px;align-self:flex-start}.machine-details{flex:1;width:100%}.payment-methods-header{width:100%;max-width:none;margin-left:0;align-items:flex-start;flex-direction:row;flex-wrap:wrap;gap:.5rem}.payment-methods-header>div{justify-content:flex-start;min-width:120px;flex:0 0 auto}}@media (max-width: 480px){.machine-info-header{gap:.75rem}.machine-photo-header{width:60px;height:60px}.payment-methods-header{gap:.25rem}.payment-methods-header>div{min-width:100px;font-size:12px}}.reviews-section{margin-top:2rem;padding:1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.reviews-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.reviews-header h3{margin:0;color:var(--text-main)}.average-rating{display:flex;align-items:center;gap:.5rem}.stars{color:#f59e42;font-size:1.1rem}.rating-text{color:var(--text-secondary);font-size:.9rem}.write-review-button{background:var(--accent-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.write-review-button:hover{background:var(--accent-hover)}.review-form{margin-bottom:2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.review-form .form-group{margin-bottom:1rem}.review-form label{display:block;margin-bottom:.5rem;color:var(--text-main);font-weight:500}.review-form select,.review-form textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-main);font-size:.9rem}.review-form textarea{resize:vertical;min-height:100px}.submit-review-button{background:var(--accent-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.submit-review-button:hover:not(:disabled){background:var(--accent-hover)}.submit-review-button:disabled{opacity:.6;cursor:not-allowed}.reviews-list{display:flex;flex-direction:column;gap:1rem}.review-item{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.review-rating{display:flex;align-items:center;gap:.5rem}.rating-number{color:var(--text-secondary);font-size:.9rem}.review-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.reviewer-name{font-weight:500;color:var(--text-main);font-size:.9rem}.review-date{color:var(--text-muted);font-size:.8rem}.review-comment{color:var(--text-main);line-height:1.5}.no-reviews{text-align:center;color:var(--text-muted);font-style:italic;padding:2rem}.products-management-page{max-width:1200px;margin:0 auto;padding:2rem}.product-form{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:2rem;margin-bottom:2rem}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.form-header h2{margin:0;color:var(--text-main)}.cancel-button{background:var(--text-muted);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.product-card{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;transition:transform .2s,box-shadow .2s}.product-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.product-image{height:50px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden}.product-image img{width:100%;height:100%;object-fit:cover}.product-placeholder{font-size:3rem;color:var(--text-muted)}.product-info{padding:1.5rem}.product-info h3{margin:0 0 .5rem;color:var(--text-main)}.product-category{display:inline-block;background:var(--accent-color);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;margin-bottom:.75rem}.product-description{color:var(--text-secondary);margin:.75rem 0;line-height:1.5}.product-price{font-weight:600;color:var(--accent-color);margin:.75rem 0;font-size:1.1rem}.product-actions{display:flex;gap:.5rem;margin-top:1rem}.edit-button,.delete-button{flex:1;padding:.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.edit-button{background:var(--accent-color);color:#fff}.edit-button:hover{background:var(--accent-hover)}.delete-button{background:#dc3545;color:#fff}.delete-button:hover{background:#c82333}.photo-preview{margin-top:1rem;display:flex;align-items:center;gap:1rem}.photo-preview img{width:80px;height:80px;object-fit:cover;border-radius:6px}.remove-photo{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem}.category-section{margin-bottom:2rem}.category-section h4{margin:0 0 1rem;color:var(--text-main);font-size:1.1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-color)}.category-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.machine-meta{margin:1rem 0;padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.last-updated{margin:0;color:var(--text-muted);font-size:.9rem;text-align:center}.admin-actions{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.admin-button{background:var(--accent-color);color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;transition:background-color .2s;border:none;cursor:pointer}.admin-button:hover{background:var(--accent-hover);color:#fff;text-decoration:none}.category-filters{display:flex;gap:.5rem;margin:1rem 0;padding:0 1rem;flex-wrap:wrap}.category-filter{background:#ffffff1a;color:var(--text-main);border:2px solid rgba(255,255,255,.2);padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 4px #0003;position:relative;overflow:hidden}.category-filter:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.category-filter:hover:before{left:100%}.category-filter:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-1px);box-shadow:0 4px 12px #0006}.category-filter.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 2px 8px #00000080}html[data-theme=light] .category-filter{background:#0000001a;border:2px solid rgba(0,0,0,.2);box-shadow:0 2px 4px #0000001a}html[data-theme=light] .category-filter:hover{box-shadow:0 4px 12px #0003}html[data-theme=light] .category-filter.active{box-shadow:0 2px 8px #0000004d}@media (max-width: 768px){.category-filters{padding:0 .5rem;gap:.25rem}.category-filter{padding:.4rem .8rem;font-size:.8rem}}
