:root{--bg: #f8f9fb;--bg-card: #ffffff;--bg-sidebar: #1a1d23;--text: #1a1d23;--text-muted: #6b7280;--border: #e5e7eb;--primary: #f59e0b;--primary-light: #fef3c7;--blue: #4da6ff;--blue-light: #e8f4ff;--green: #22c55e;--green-light: #dcfce7;--orange: #f59e0b;--orange-light: #fef3c7;--red: #ef4444;--red-light: #fee2e2;--purple: #8b5cf6;--purple-light: #ede9fe;--sidebar-width: 240px;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08);--shadow-lg: 0 4px 12px rgba(0,0,0,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;min-height:100vh}#root{min-height:100vh}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}input,select,textarea,button{font:inherit}input,select,textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);transition:border-color .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}input[type=checkbox]{width:auto}table{width:100%;border-collapse:collapse}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{font-size:1rem;font-weight:600;display:flex;align-items:center}.nav-section-label{padding:.75rem 1rem .2rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:#ffffff59;font-weight:600}.nav-list{list-style:none;padding:.25rem 0}.nav-list li a{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;color:#9ca3af;transition:all .15s;text-decoration:none;font-size:.9rem}.nav-list li a:hover{color:#fff;background:#ffffff0d}.nav-list li a.active{color:#fff;background:#f59e0b33;border-right:3px solid var(--primary)}.sidebar-footer{margin-top:auto;padding:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:.25rem}.btn-logout{display:flex;align-items:center;gap:.5rem;padding:.5rem;color:#9ca3af;font-size:.85rem;border:none;background:none;cursor:pointer;border-radius:var(--radius)}.btn-logout:hover{color:#fff;background:#ffffff0d}.main-content{flex:1;margin-left:var(--sidebar-width);padding:1.5rem 2rem;min-height:100vh}.mobile-topbar,.sidebar-overlay{display:none}.page{max-width:1200px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.page-header h1{font-size:1.4rem;font-weight:700;display:flex;align-items:center}.header-actions{display:flex;gap:.5rem;align-items:center}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem;display:flex;align-items:center;gap:1rem}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-value{font-size:1.5rem;font-weight:700;display:block}.stat-label{font-size:.8rem;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:#e08e0a}.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}.btn-ghost:hover{background:var(--bg)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;cursor:pointer;border-radius:var(--radius);color:var(--text-muted);transition:all .15s}.btn-icon:hover{background:var(--bg);color:var(--text)}.btn-icon-danger:hover{background:var(--red-light);color:var(--red)}.btn-icon-success:hover{background:var(--green-light);color:var(--green)}.badge{display:inline-flex;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500;border:none;cursor:pointer;transition:opacity .15s}.badge:hover{opacity:.8}.badge-green{background:var(--green-light);color:#15803d}.badge-orange{background:var(--orange-light);color:#b45309}.badge-red{background:var(--red-light);color:#b91c1c}.badge-blue{background:var(--blue-light);color:#1d4ed8}.badge-gray{background:#f3f4f6;color:#6b7280}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-muted)}.form-actions{display:flex;gap:.5rem;justify-content:flex-end}.table-wrapper{overflow-x:auto}table th{text-align:left;padding:.75rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:2px solid var(--border)}table td{padding:.75rem;border-bottom:1px solid var(--border)}table tbody tr:hover{background:#00000005}.action-btns{display:flex;gap:.25rem}.category-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.category-tab{padding:.4rem .8rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;font-size:.85rem;transition:all .15s}.category-tab:hover{border-color:var(--primary);color:var(--text)}.category-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.template-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .15s}.template-card:hover{box-shadow:var(--shadow-lg)}.template-inactive{opacity:.5}.template-preview{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:#f3f4f6;cursor:pointer;overflow:hidden}.template-preview img{width:100%;height:100%;object-fit:contain}.template-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-muted)}.template-info{padding:.75rem}.template-info strong{display:block;font-size:.9rem}.template-info small{color:var(--text-muted)}.template-actions{display:flex;gap:.25rem;padding:0 .75rem .75rem}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.asset-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;position:relative}.asset-preview{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#f9fafb;padding:.5rem}.asset-preview img{max-width:100%;max-height:100%;object-fit:contain}.asset-info{padding:.5rem}.asset-name{font-size:.8rem;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-info small{color:var(--text-muted);font-size:.7rem}.asset-delete{position:absolute;top:4px;right:4px;opacity:0;transition:opacity .15s;background:#ffffffe6!important;border-radius:50%}.asset-card:hover .asset-delete{opacity:1}.settings-list{display:flex;flex-direction:column}.setting-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border)}.setting-item:last-child{border-bottom:none}.setting-info{flex:1}.setting-info strong{display:block;margin-bottom:.2rem}.setting-info small{color:var(--text-muted)}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.75rem 1.25rem;border-radius:var(--radius);font-size:.875rem;box-shadow:var(--shadow-lg);animation:slideIn .2s ease}.toast-success{background:var(--green);color:#fff}.toast-error{background:var(--red);color:#fff}.toast-info{background:var(--blue);color:#fff}.toast-warning{background:var(--orange);color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .2s}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:99}.main-content{margin-left:0;padding:3.5rem 1rem 1rem}.mobile-topbar{display:flex;align-items:center;gap:.75rem;position:fixed;top:0;left:0;right:0;padding:.75rem 1rem;background:var(--bg-card);border-bottom:1px solid var(--border);z-index:98}.mobile-title{font-weight:600}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}.template-grid{grid-template-columns:repeat(2,1fr)}.asset-grid{grid-template-columns:repeat(3,1fr)}}.editor-layout{position:fixed;inset:0;left:var(--sidebar-width);display:flex;flex-direction:column;background:#e5e7eb;z-index:50}.editor-toolbar{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:var(--bg-card);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0}.toolbar-section{display:flex;align-items:center;gap:.15rem}.toolbar-divider{width:1px;height:24px;background:var(--border);margin:0 .35rem;flex-shrink:0}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:none;cursor:pointer;border-radius:6px;color:var(--text-muted);transition:all .1s}.toolbar-btn:hover{background:var(--bg);color:var(--text)}.toolbar-btn.active{background:var(--primary-light);color:var(--primary)}.toolbar-btn:disabled{opacity:.3;cursor:default}.toolbar-btn-danger:hover{color:var(--red);background:var(--red-light)}.toolbar-btn-labeled{display:flex;align-items:center;gap:.3rem;padding:.35rem .6rem;border:none;background:none;cursor:pointer;border-radius:6px;color:var(--text-muted);font-size:.75rem;font-weight:500;transition:all .1s;white-space:nowrap}.toolbar-btn-labeled:hover{background:var(--bg);color:var(--text)}.toolbar-label{font-size:.75rem;color:var(--text-muted);min-width:40px;text-align:center}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.editor-body{display:flex;flex:1;overflow:hidden}.editor-canvas-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.editor-canvas-scroll{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:#d1d5db;background-image:linear-gradient(45deg,#c9cdd3 25%,transparent 25%),linear-gradient(-45deg,#c9cdd3 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#c9cdd3 75%),linear-gradient(-45deg,transparent 75%,#c9cdd3 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;padding:2rem}.canvas-container{box-shadow:0 4px 24px #00000026;border-radius:2px;line-height:0}.editor-statusbar{display:flex;align-items:center;gap:1rem;padding:.4rem 1rem;background:var(--bg-card);border-top:1px solid var(--border);font-size:.75rem;color:var(--text-muted);flex-shrink:0}.template-name-input{margin-left:auto;border:none;background:transparent;text-align:right;font-size:.75rem;color:var(--text);padding:.2rem .5rem;width:200px}.template-name-input:focus{background:var(--bg);border-radius:4px}.property-panel,.layer-panel{width:260px;background:var(--bg-card);border-left:1px solid var(--border);overflow-y:auto;flex-shrink:0}.layer-panel{border-left:none;border-right:1px solid var(--border);width:220px}.asset-library-panel{width:340px;background:var(--bg-card);border-left:1px solid var(--border);overflow-y:auto;overflow-x:hidden;flex-shrink:0;display:flex;flex-direction:column}.asset-lib-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:1rem}.asset-lib-category{border-bottom:1px solid var(--border)}.asset-lib-folder{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--text);transition:background .1s;-webkit-user-select:none;user-select:none}.asset-lib-folder:hover{background:#00000008}.asset-lib-folder-name{flex:1}.asset-lib-count{font-size:.7rem;font-weight:400;color:var(--text-muted);background:var(--bg);padding:.1rem .4rem;border-radius:999px}.asset-lib-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:.5rem .75rem .75rem}.asset-lib-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.4rem;border-radius:8px;cursor:grab;transition:background .1s;-webkit-user-select:none;user-select:none;overflow:hidden}.asset-lib-item:hover{background:var(--primary-light)}.asset-lib-item:active{cursor:grabbing}.asset-lib-item img,.asset-lib-item .secure-image-loading,.asset-lib-item .secure-image-placeholder{width:85px;height:85px;object-fit:contain;border-radius:6px}.asset-lib-item span{font-size:.65rem;color:var(--text-muted);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:85px}.secure-image-loading{background:var(--bg);animation:pulse 1.5s ease-in-out infinite}.secure-image-placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--text-muted);font-size:.75rem}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.7}}.editor-canvas-scroll.drag-over{outline:2px dashed var(--primary);outline-offset:-2px}.panel-header{padding:.75rem 1rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border)}.panel-empty{padding:1.5rem 1rem;color:var(--text-muted);font-size:.85rem;text-align:center}.panel-content{padding:.75rem}.prop-section{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.prop-section:last-child{border-bottom:none}.prop-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem}.prop-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.prop-field{display:flex;flex-direction:column;gap:.15rem}.prop-field label{font-size:.7rem;color:var(--text-muted)}.prop-field input,.prop-field select{font-size:.8rem;padding:.3rem .5rem}.prop-field input[type=range]{padding:0}.prop-field input[type=color]{width:32px;height:28px;padding:1px}.color-input-wrap{display:flex;gap:.3rem;align-items:center}.text-style-btns{display:flex;gap:.15rem;align-items:center}.style-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--bg-card);cursor:pointer;border-radius:4px;font-size:.85rem;transition:all .1s}.style-btn:hover{background:var(--bg)}.style-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.layer-list{overflow-y:auto}.layer-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;cursor:pointer;border-bottom:1px solid rgba(0,0,0,.04);transition:background .1s;font-size:.8rem}.layer-item:hover{background:#00000008}.layer-active{background:var(--primary-light)!important}.layer-locked{opacity:.5}.layer-icon{flex-shrink:0;color:var(--text-muted)}.layer-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--text-muted);border-radius:3px;opacity:.5;transition:opacity .1s}.layer-item:hover .layer-btn{opacity:1}.layer-btn:hover{background:#00000014}.asset-picker-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center}.asset-picker{background:var(--bg-card);border-radius:12px;box-shadow:0 8px 32px #0003;width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column}.asset-picker-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.asset-picker-header h3{font-size:1rem}.asset-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.75rem;padding:1rem;overflow-y:auto;flex:1}.asset-picker-item{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.5rem;border-radius:var(--radius);cursor:pointer;transition:background .1s}.asset-picker-item:hover{background:var(--bg)}.asset-picker-item img{width:80px;height:80px;object-fit:contain}.asset-picker-item span{font-size:.7rem;color:var(--text-muted);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.format-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.format-picker-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;transition:all .15s;text-align:center}.format-picker-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.format-preview{border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;background:var(--bg)}.customer-page{min-height:100vh;padding:2rem}.customer-gallery-header{text-align:center;margin-bottom:2rem}.customer-gallery-header h1{font-size:1.8rem;margin-bottom:.5rem}.customer-gallery-header p{color:var(--text-muted);font-size:1.1rem}.customer-section{margin-bottom:2rem}.customer-section h2{font-size:1.1rem;margin-bottom:1rem;color:var(--text-muted)}.customer-format-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.customer-format-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem;background:var(--bg-card);border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .15s;text-align:center}.customer-format-card:hover{border-color:var(--primary)}.customer-format-card.active{border-color:var(--primary);background:var(--primary-light)}.customer-format-shape{border:2px dashed var(--border);background:var(--bg)}.customer-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.customer-template-card{background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:all .15s}.customer-template-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.customer-template-preview{aspect-ratio:4/3;background:#f3f4f6;display:flex;align-items:center;justify-content:center;overflow:hidden}.customer-template-preview img{width:100%;height:100%;object-fit:contain}.customer-template-placeholder{color:var(--text-muted)}.customer-template-info{padding:1rem;display:flex;align-items:center;justify-content:space-between}.customer-template-info strong{font-size:.95rem}.customer-empty{color:var(--text-muted);text-align:center;padding:2rem}.customer-loading{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--text-muted);font-size:1.1rem}.customer-editor-layout{position:fixed;inset:0;left:var(--sidebar-width);display:flex;flex-direction:column;background:#e5e7eb;z-index:50}.customer-toolbar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0}.customer-tool-btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.5rem .75rem;border:none;background:none;cursor:pointer;border-radius:8px;color:var(--text-muted);font-size:.65rem;min-width:55px;transition:all .1s}.customer-tool-btn:hover{background:var(--bg);color:var(--text)}.customer-tool-btn:disabled{opacity:.3;cursor:default}.customer-tool-danger:hover{color:var(--red);background:var(--red-light)}.customer-tool-submit{background:var(--primary);color:#fff!important;border-radius:12px;padding:.6rem 1.25rem;font-size:.8rem;font-weight:600}.customer-tool-submit:hover{background:#e08e0a}.customer-toolbar-divider{width:1px;height:40px;background:var(--border);margin:0 .25rem}.customer-zoom{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-muted)}.customer-editor-body{display:flex;flex:1;overflow:hidden}.customer-canvas-area{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:2rem;background:#d1d5db;background-image:linear-gradient(45deg,#c9cdd3 25%,transparent 25%),linear-gradient(-45deg,#c9cdd3 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#c9cdd3 75%),linear-gradient(-45deg,transparent 75%,#c9cdd3 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.customer-name-bar{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0}.customer-name-bar label{font-size:.85rem;font-weight:500;white-space:nowrap}.customer-name-bar input{max-width:300px}.customer-done{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.customer-done-icon{width:80px;height:80px;border-radius:50%;background:var(--green);color:#fff;font-size:2.5rem;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.customer-done h2{font-size:1.5rem;margin-bottom:.5rem}.customer-done p{color:var(--text-muted);font-size:1.1rem}.dropzone{border:2px dashed var(--border);border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-card);margin-bottom:1.25rem}.dropzone:hover{border-color:var(--primary);background:var(--primary-light)}.dropzone-active{border-color:var(--primary);background:var(--primary-light);border-style:solid}.dropzone-uploading{opacity:.7;pointer-events:none}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-muted)}.dropzone-content p{font-size:.95rem;font-weight:500;margin:0}.dropzone-content small{font-size:.8rem}.dropzone-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.kiosk-mode{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:linear-gradient(135deg,#1a1d23,#2c3038);color:#f5f5f5;overflow:hidden;user-select:none;-webkit-user-select:none}.kiosk-editor .property-panel{background:#2c3038;border-color:#3a3f48;color:#f5f5f5}.kiosk-editor .property-panel .panel-header{color:#8e95a5;border-color:#3a3f48}.kiosk-editor .property-panel .prop-section{border-color:#3a3f48}.kiosk-editor .property-panel .prop-section-title,.kiosk-editor .property-panel label{color:#8e95a5}.kiosk-editor .property-panel input,.kiosk-editor .property-panel select{background:#1e2128;border-color:#ffffff1f;color:#f5f5f5}.kiosk-editor .property-panel select option{background:#1e2128;color:#f5f5f5}.kiosk-editor .property-panel .style-btn{background:#ffffff14;border-color:#ffffff1f;color:#ccc}.kiosk-editor .property-panel .style-btn.active{background:#4e73df4d;border-color:var(--primary);color:#fff}.kiosk-editor .property-panel .panel-empty{color:#8e95a5}.kiosk-start{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:2rem}.kiosk-start-content{text-align:center}.kiosk-logo{width:96px;height:96px;border-radius:24px;background:linear-gradient(135deg,var(--primary),#5b8af5);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:#fff;box-shadow:0 8px 32px #4e73df66}.kiosk-title{font-size:2.5rem;font-weight:700;margin:0 0 .5rem;background:linear-gradient(135deg,#fff,#b0c4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.kiosk-subtitle{font-size:1.1rem;color:#8e95a5;margin:0 0 2.5rem}.kiosk-start-actions{display:flex;flex-direction:column;gap:1rem;align-items:center}.kiosk-btn-primary{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 2.5rem;font-size:1.15rem;font-weight:600;background:linear-gradient(135deg,var(--primary),#5b8af5);color:#fff;border:none;border-radius:16px;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #4e73df59;min-width:280px}.kiosk-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px #4e73df80}.kiosk-btn-primary:active{transform:translateY(0)}.kiosk-btn-primary:disabled{opacity:.5;cursor:default;transform:none}.kiosk-btn-large{padding:1.25rem 3rem;font-size:1.3rem;min-width:320px}.kiosk-btn-secondary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;font-size:1rem;font-weight:500;background:#ffffff14;color:#b0bec5;border:1px solid rgba(255,255,255,.12);border-radius:12px;cursor:pointer;transition:all .2s}.kiosk-btn-secondary:hover{background:#ffffff26;color:#fff}.kiosk-btn-sm{padding:.5rem 1rem;font-size:.85rem}.kiosk-btn-ghost{display:flex;align-items:center;gap:.4rem;background:none;border:none;color:#8e95a5;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;border-radius:8px;transition:color .15s}.kiosk-btn-ghost:hover{color:#fff}.kiosk-gallery{min-height:100vh;min-height:100dvh;padding:1.5rem 2rem;overflow-y:auto}.kiosk-gallery-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.kiosk-gallery-header h1{font-size:1.5rem;font-weight:700;margin:0;display:flex;align-items:center}.kiosk-back-btn{width:48px;height:48px;border-radius:12px;background:#ffffff14;border:none;color:#b0bec5;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.kiosk-back-btn:hover{background:#ffffff26;color:#fff}.kiosk-section{margin-bottom:2rem}.kiosk-section-title{font-size:1rem;font-weight:600;color:#8e95a5;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.kiosk-format-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.kiosk-format-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem;background:#ffffff0d;border:2px solid transparent;border-radius:16px;cursor:pointer;transition:all .2s;color:#ccc}.kiosk-format-card:hover{background:#ffffff1a}.kiosk-format-card.active{border-color:var(--primary);background:#4e73df26;color:#fff}.kiosk-format-card strong{font-size:.9rem}.kiosk-format-card small{font-size:.75rem;color:#8e95a5}.kiosk-format-shape{background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.kiosk-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.25rem}.kiosk-template-card{display:flex;flex-direction:column;background:#ffffff0f;border-radius:16px;overflow:hidden;cursor:pointer;transition:all .2s;border:2px solid transparent}.kiosk-template-card:hover{background:#ffffff1f;border-color:var(--primary);transform:translateY(-2px)}.kiosk-template-preview{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:#ffffff08;overflow:hidden}.kiosk-template-preview img{width:100%;height:100%;object-fit:contain}.kiosk-template-placeholder{color:#555}.kiosk-template-name{padding:.75rem 1rem;font-size:.85rem;font-weight:500}.kiosk-loading,.kiosk-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:#8e95a5;font-size:1rem}.kiosk-editor{display:flex;flex-direction:column;height:100vh;height:100dvh}.kiosk-editor-body{flex:1;display:flex;overflow:hidden}.kiosk-canvas-area{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:#3a3f48;background-image:linear-gradient(45deg,#353a42 25%,transparent 25%),linear-gradient(-45deg,#353a42 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#353a42 75%),linear-gradient(-45deg,transparent 75%,#353a42 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;padding:1.5rem}.kiosk-editor .asset-library-panel{background:#2c3038;border-color:#3a3f48;color:#f5f5f5}.kiosk-editor .asset-lib-folder{color:#ccc}.kiosk-editor .asset-lib-folder:hover{background:#ffffff0d}.kiosk-editor .asset-lib-count{background:#ffffff14;color:#8e95a5}.kiosk-editor .asset-lib-grid{background:transparent}.kiosk-editor .asset-lib-item:hover{background:#4e73df33}.kiosk-editor .asset-lib-item span{color:#8e95a5}.kiosk-editor .panel-header{color:#8e95a5;border-color:#3a3f48}.kiosk-editor input{background:#ffffff14;border-color:#ffffff1f;color:#f5f5f5}.kiosk-toolbar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#1e2128;border-top:1px solid #3a3f48;flex-shrink:0}.kiosk-tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.5rem .75rem;background:none;border:none;color:#8e95a5;cursor:pointer;border-radius:10px;transition:all .15s;font-size:.65rem;min-width:48px}.kiosk-tool-btn:hover{background:#ffffff14;color:#fff}.kiosk-tool-btn.active{background:#4e73df33;color:var(--primary)}.kiosk-tool-btn:disabled{opacity:.3;cursor:default}.kiosk-tool-danger:hover{color:#e74c3c}.kiosk-toolbar-divider{width:1px;height:32px;background:#3a3f48;flex-shrink:0}.kiosk-zoom-label{font-size:.75rem;color:#8e95a5;min-width:36px;text-align:center}.kiosk-name-input input{padding:.5rem .75rem;border-radius:8px;border:1px solid #3a3f48;background:#ffffff0f;color:#f5f5f5;font-size:.85rem;width:180px}.kiosk-bg-picker{display:flex;gap:.5rem;padding:.75rem 1rem;background:#1e2128;border-top:1px solid #3a3f48;flex-wrap:wrap;align-items:center;justify-content:center}.kiosk-bg-color{width:40px;height:40px;border-radius:10px;cursor:pointer;transition:transform .15s}.kiosk-bg-color:hover{transform:scale(1.15)}.kiosk-tool-finish{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.5rem;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s}.kiosk-tool-finish:hover{transform:translateY(-1px);box-shadow:0 4px 12px #27ae6066}.kiosk-preview{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:2rem}.kiosk-preview-content{display:flex;flex-direction:column;align-items:center;gap:2rem;max-width:600px;width:100%}.kiosk-preview-image{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px #0000004d;max-width:400px;width:100%}.kiosk-preview-image img{width:100%;height:auto;display:block;border-radius:8px}.kiosk-preview-actions-main{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.kiosk-preview-actions-main h2{font-size:1.5rem;margin:0}.kiosk-preview-bottom{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap}.kiosk-preview-done{text-align:center}.kiosk-preview-done h2{font-size:1.5rem;margin:.75rem 0 .5rem}.kiosk-preview-done p{color:#8e95a5;margin:0}.kiosk-done-icon{width:80px;height:80px;border-radius:50%;background:#27ae6033;color:#27ae60;display:flex;align-items:center;justify-content:center;margin:0 auto}.spin{animation:spin 1s linear infinite}.kiosk-history{min-height:100vh;min-height:100dvh;padding:1.5rem 2rem;overflow-y:auto}.kiosk-history-content{max-width:700px;margin:0 auto}.kiosk-history-list{display:flex;flex-direction:column;gap:.75rem}.kiosk-history-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:#ffffff0f;border-radius:12px;transition:background .15s}.kiosk-history-item:hover{background:#ffffff1a}.kiosk-history-info{display:flex;flex-direction:column;gap:.25rem}.kiosk-history-info strong{font-size:1rem}.kiosk-history-info small{font-size:.8rem;color:#8e95a5}.kiosk-status{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:999px;display:inline-block;width:fit-content}.kiosk-status-submitted{background:#e67e2233;color:#e67e22}.kiosk-status-approved{background:#27ae6033;color:#27ae60}.kiosk-status-printed{background:#4e73df33;color:#5b8af5}.pin-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.pin-dialog{background:#2c3038;border-radius:24px;padding:2.5rem 2rem;text-align:center;min-width:340px;position:relative;box-shadow:0 16px 64px #00000080}.pin-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#8e95a5;cursor:pointer}.pin-close:hover{color:#fff}.pin-dialog h2{font-size:1.3rem;margin:0 0 .25rem;color:#fff}.pin-dialog p{font-size:.9rem;color:#8e95a5;margin:0 0 1.5rem}.pin-display{display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid #555;transition:all .15s}.pin-dot.filled{background:var(--primary);border-color:var(--primary)}.pin-error{color:#e74c3c;font-size:.85rem;margin:-1rem 0 1rem}.pin-numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:280px;margin:0 auto}.pin-key{width:72px;height:72px;border-radius:50%;background:#ffffff14;border:none;color:#fff;font-size:1.5rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;margin:0 auto}.pin-key:hover{background:#ffffff2e}.pin-key:active{background:#4e73df4d;transform:scale(.95)}.pin-key:disabled{opacity:.4}.pin-key-spacer{visibility:hidden}.pin-key-action{background:#e74c3c26;color:#e74c3c}.pin-key-action:hover{background:#e74c3c4d}.login-screen{min-height:100vh;display:grid;place-items:center;padding:2rem 1rem;background:radial-gradient(1000px 600px at 10% -10%,rgba(245,158,11,.12),transparent 60%),radial-gradient(900px 500px at 110% 110%,rgba(77,166,255,.1),transparent 55%),var(--bg)}.login-card{width:100%;max-width:400px;background:var(--bg-card);border-radius:16px;box-shadow:0 10px 40px #1118271a,0 2px 8px #1118270a;padding:2.25rem 2rem 2rem;border:1px solid var(--border)}.login-brand{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}.login-brand-logo{width:40px;height:40px;border-radius:10px;background:var(--primary);color:#fff;display:grid;place-items:center;box-shadow:0 4px 12px #f59e0b59}.login-brand-name{font-size:1.15rem;font-weight:700;line-height:1.1}.login-brand-subtitle{font-size:.78rem;color:var(--text-muted);letter-spacing:.3px}.login-title{font-size:1.35rem;font-weight:700;margin:1.5rem 0 .25rem}.login-subtitle{font-size:.9rem;color:var(--text-muted);margin-bottom:1.5rem}.login-field{margin-bottom:1rem}.login-field label{display:block;font-size:.8rem;font-weight:500;margin-bottom:.35rem;color:var(--text)}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-wrap svg{position:absolute;left:.75rem;color:var(--text-muted);pointer-events:none}.login-input-wrap input{padding-left:2.4rem}.login-input-wrap input[type=password]{letter-spacing:.1em}.login-error{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.6rem .75rem;background:var(--red-light);color:#991b1b;border-radius:var(--radius);font-size:.85rem;border:1px solid rgba(239,68,68,.2)}.login-submit{width:100%;padding:.7rem;background:var(--primary);color:#fff;border:0;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,transform .05s;display:flex;align-items:center;justify-content:center;gap:.4rem}.login-submit:hover:not(:disabled){background:#e08e0a}.login-submit:active:not(:disabled){transform:translateY(1px)}.login-submit:disabled{opacity:.6;cursor:wait}.login-back{width:100%;margin-top:.5rem;padding:.55rem;background:transparent;color:var(--text-muted);border:0;border-radius:var(--radius);font-size:.85rem;cursor:pointer}.login-back:hover{color:var(--text);background:#00000008}.login-footer{margin-top:1.5rem;font-size:.75rem;color:var(--text-muted);text-align:center}.login-step-hint{background:var(--blue-light);color:#1e40af;border:1px solid rgba(77,166,255,.25);border-radius:var(--radius);padding:.6rem .75rem;font-size:.85rem;margin-bottom:1rem;display:flex;gap:.5rem;align-items:flex-start}.login-code-input input{text-align:center;font-size:1.35rem;letter-spacing:.4em;font-family:SF Mono,Menlo,Consolas,monospace;padding:.75rem .5rem}@keyframes login-spin{to{transform:rotate(360deg)}}.login-spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;animation:login-spin .7s linear infinite}@media(max-width:768px){.editor-layout,.customer-editor-layout{left:0}.property-panel,.layer-panel{width:200px}.asset-library-panel{width:280px}.asset-lib-grid{grid-template-columns:repeat(2,1fr)}.asset-lib-item img,.asset-lib-item .secure-image-loading,.asset-lib-item .secure-image-placeholder{width:70px;height:70px}.editor-canvas-scroll,.customer-canvas-area,.customer-page{padding:1rem}.customer-format-grid,.customer-template-grid{grid-template-columns:repeat(2,1fr)}.customer-tool-btn span{display:none}.customer-tool-submit span{display:inline}}
