*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#302929}.login-form{background:#fff;padding:2.5rem;border-radius:8px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:1rem}.login-logo{display:block;height:48px;width:auto;margin:0 auto .75rem;border-radius:6px}.login-form input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem}.login-form button{padding:.75rem;background:#302929;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.login-form button:hover{background:#16213e}.login-form button:disabled{opacity:.6;cursor:not-allowed}.error{background:#fee;color:#c33;padding:.5rem .75rem;border-radius:4px;font-size:.85rem}.app-header{background:#302929;color:#fff;padding:0 1.5rem;height:56px;display:flex;align-items:center;justify-content:space-between}.header-left,.header-right{display:flex;align-items:center;gap:1rem}.logo{display:flex;align-items:center;text-decoration:none}.logo-img{height:36px;width:auto;border-radius:4px}.product-count{font-size:.85rem;opacity:.7}.connection-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.connection-dot.online{background:#4caf50}.connection-dot.offline{background:#f44336}.nav-link{color:#ccc;text-decoration:none;font-size:.9rem}.nav-link:hover{color:#fff}.username{font-size:.85rem;opacity:.8}.btn-logout{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.3rem .75rem;border-radius:4px;cursor:pointer;font-size:.8rem}.btn-logout:hover{border-color:#fff}.app-main{padding:1.5rem;max-width:1200px;margin:0 auto}.toast{position:fixed;top:70px;right:20px;background:#302929;color:#fff;padding:.75rem 1.25rem;border-radius:6px;font-size:.9rem;z-index:1000;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.page h2{margin-bottom:1rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.search-form{display:flex;gap:.5rem}.search-form input{padding:.4rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:.9rem}.search-form button{padding:.4rem 1rem;background:#302929;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.products-table{width:100%;border-collapse:collapse;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #00000014}.products-table th{background:#f8f9fa;text-align:left;padding:.6rem .75rem;font-size:.8rem;color:#666;text-transform:uppercase}.products-table td{padding:.5rem .75rem;border-top:1px solid #eee;font-size:.9rem;vertical-align:middle}.products-table tr.highlight{background:#fffde7}.thumb-cell{width:50px}.thumb{width:40px;height:40px;object-fit:cover;border-radius:4px}.thumb-placeholder{width:40px;height:40px;background:#eee;border-radius:4px}.product-link{color:#302929;text-decoration:none;font-weight:500}.product-link:hover{text-decoration:underline}.date-cell{font-size:.8rem;color:#888;white-space:nowrap}.status-badge{display:inline-block;padding:.1rem .4rem;border-radius:3px;font-size:.7rem;font-weight:600;margin-left:.3rem}.status-badge.complete{background:#e8f5e9;color:#2e7d32}.status-badge.downloading{background:#e3f2fd;color:#1565c0}.status-badge.partial{background:#fff3e0;color:#e65100}.status-badge.pending{background:#f5f5f5;color:#999}.btn-delete{background:transparent;border:1px solid #e57373;color:#e57373;padding:.2rem .6rem;border-radius:3px;cursor:pointer;font-size:.75rem}.btn-delete:hover{background:#ffebee}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem}.pagination button{padding:.4rem 1rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer}.pagination button:disabled{opacity:.4;cursor:default}.empty-state{color:#888;font-style:italic;padding:2rem 0}.product-detail{max-width:900px}.back-link{color:#666;text-decoration:none;font-size:.9rem;display:inline-block;margin-bottom:.5rem}.back-link:hover{color:#333}.source-link{color:#1976d2;font-size:.85rem;display:inline-block;margin-bottom:.75rem}.sku{color:#888;font-size:.85rem;margin-bottom:1rem}.price-range{font-size:1.1rem;font-weight:600;color:#d32f2f;margin-bottom:1rem}.detail-section{margin-bottom:1.5rem}.detail-section h3{font-size:1rem;margin-bottom:.5rem;color:#555}.detail-table{border-collapse:collapse;width:100%;max-width:600px;background:#fff;border-radius:4px;overflow:hidden}.detail-table th,.detail-table td{padding:.4rem .75rem;border:1px solid #eee;font-size:.85rem}.detail-table th{background:#f8f9fa;text-align:left}.attributes-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.25rem}.attr-row{display:flex;gap:.5rem;background:#fff;padding:.35rem .75rem;border-radius:3px}.attr-row dt{font-weight:600;min-width:120px;color:#666;font-size:.85rem}.attr-row dd{font-size:.85rem}.variants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.variant-card{background:#fff;padding:.75rem;border-radius:6px;border:1px solid #eee}.variant-card strong{display:block;margin-bottom:.3rem}.variant-thumb{width:48px;height:48px;object-fit:cover;border-radius:4px;margin-bottom:.3rem}.size-list{list-style:none;font-size:.8rem;color:#666}.variant-price{font-size:.85rem;color:#e65100;font-weight:600}.package-info{list-style:none;font-size:.85rem;color:#555}.package-info li{padding:.2rem 0}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.image-card{position:relative;cursor:pointer;border-radius:4px;overflow:hidden;background:#eee;aspect-ratio:1}.image-card img{width:100%;height:100%;object-fit:cover}.image-num{position:absolute;bottom:4px;right:4px;background:#0009;color:#fff;font-size:.7rem;padding:.1rem .3rem;border-radius:3px}.image-color-badge{position:absolute;top:4px;left:4px;background:#000000a6;color:#fff;font-size:.65rem;padding:.1rem .35rem;border-radius:3px;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.description-html{background:#fff;padding:1rem;border-radius:6px;font-size:.9rem;line-height:1.6;overflow:auto}.description-html img{max-width:100%;height:auto}.lightbox{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;cursor:pointer}.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain}.admin-section{margin-bottom:2rem}.admin-section h3{margin-bottom:.75rem}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:6px;overflow:hidden;margin-bottom:1rem;box-shadow:0 1px 3px #00000014}.admin-table th{background:#f8f9fa;text-align:left;padding:.5rem .75rem;font-size:.8rem;color:#666}.admin-table td{padding:.5rem .75rem;border-top:1px solid #eee;font-size:.85rem}.inactive-row{opacity:.5}.btn-sm{padding:.2rem .5rem;border:1px solid #ccc;border-radius:3px;background:#fff;cursor:pointer;font-size:.75rem}.btn-sm:hover{background:#f5f5f5}.admin-form{display:flex;gap:.5rem;flex-wrap:wrap}.admin-form input,.admin-form select{padding:.4rem .6rem;border:1px solid #ccc;border-radius:4px;font-size:.85rem}.admin-form button{padding:.4rem 1rem;background:#302929;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.key-created{background:#e8f5e9;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.85rem}.full-key{display:block;margin-top:.4rem;background:#fff;padding:.5rem;border-radius:4px;word-break:break-all;font-size:.8rem;-webkit-user-select:all;user-select:all}.app-main--dashboard{max-width:none;padding:0}.dashboard-master-detail{display:flex;height:calc(100vh - 56px);overflow:hidden}.dashboard-sidebar{width:340px;min-width:340px;border-right:1px solid #e0e0e0;background:#fff;display:flex;flex-direction:column}.dashboard-sidebar__header{padding:1rem;border-bottom:1px solid #eee;flex-shrink:0}.dashboard-sidebar__header h2{font-size:1rem;margin-bottom:.5rem}.dashboard-sidebar__header .search-form input{flex:1;min-width:0}.dashboard-sidebar__list{flex:1;overflow-y:auto;padding:.5rem}.dashboard-sidebar__footer{padding:.75rem;border-top:1px solid #eee;flex-shrink:0}.dashboard-sidebar__footer .pagination{margin-top:0}.dashboard-detail{flex:1;overflow-y:auto;padding:1.5rem;background:#f5f5f5}.sidebar-status{padding:1rem;color:#888}.product-card{display:flex;align-items:flex-start;gap:.65rem;padding:.6rem;border-radius:6px;cursor:pointer;position:relative;transition:background .15s}.product-card:hover{background:#f0f0f0}.product-card--selected{background:#e3f2fd}.product-card--selected:hover{background:#bbdefb}.product-card--highlight-created,.compact-card--highlight-created{background:#e8f5e9;animation:highlightFadeGreen 5s ease forwards}.product-card--highlight-updated,.compact-card--highlight-updated{background:#fffde7;animation:highlightFadeYellow 5s ease forwards}.product-card--highlight-unchanged,.compact-card--highlight-unchanged{background:#e3f2fd;animation:highlightFadeBlue 5s ease forwards}@keyframes highlightFadeGreen{0%{background:#e8f5e9}80%{background:#e8f5e9}to{background:transparent}}@keyframes highlightFadeYellow{0%{background:#fffde7}80%{background:#fffde7}to{background:transparent}}@keyframes highlightFadeBlue{0%{background:#e3f2fd}80%{background:#e3f2fd}to{background:transparent}}.product-card__thumb{width:48px;height:48px;flex-shrink:0;border-radius:4px;overflow:hidden;background:#eee}.product-card__thumb img{width:100%;height:100%;object-fit:cover}.product-card__info{flex:1;min-width:0}.product-card__title{font-size:.85rem;font-weight:500;color:#333;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.product-card__meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-top:.25rem;font-size:.75rem;color:#888}.tag-badge{display:inline-block;padding:3px 10px;border-radius:50px;font-size:.65rem;font-weight:600;line-height:1.4;white-space:nowrap}.tag-badge--detail{font-size:.8rem;padding:4px 14px;border-radius:50px;margin-bottom:.5rem}.product-card__delete{position:absolute;top:.4rem;right:.4rem;background:transparent;border:none;color:#ccc;cursor:pointer;font-size:.9rem;padding:.1rem .3rem;border-radius:3px;opacity:0;transition:opacity .15s;line-height:1}.product-card:hover .product-card__delete{opacity:1}.product-card__delete:hover{color:#e57373;background:#ffebee}.dashboard-detail__empty{display:flex;align-items:center;justify-content:center;height:100%;color:#aaa;font-size:1.1rem}.detail-loading{padding:2rem;color:#888}.product-detail-panel{max-width:900px}.product-detail-panel h2{margin-bottom:0}.product-detail-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.product-detail-header__actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.translation-badge{font-size:.75rem;padding:2px 8px;border-radius:4px;white-space:nowrap}.translation-badge--pending{background:#fff3cd;color:#856404}.translation-badge--translating{background:#cce5ff;color:#004085}.translation-badge--failed{background:#f8d7da;color:#721c24;cursor:help}.btn-lang-toggle{padding:2px 10px;font-size:.75rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-weight:600}.btn-lang-toggle:hover{background:#f0f0f0}.btn-retranslate{padding:2px 8px;font-size:1rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;line-height:1}.btn-retranslate--text{font-size:.8rem;padding:3px 10px}.btn-retranslate:hover{background:#f0f0f0}.btn-retranslate:disabled{opacity:.5;cursor:not-allowed}.section-header-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.section-header-row h3{margin-bottom:0}.summary-text{background:#fff;padding:1rem;border-radius:6px;font-size:.9rem;line-height:1.7;color:#444;white-space:pre-line}.summary-empty{color:#999;font-style:italic;font-size:.85rem}.btn-view-toggle{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.2rem .5rem;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1}.btn-view-toggle:hover{border-color:#fff;background:#ffffff1a}.compact-layout{display:flex;height:calc(100vh - 56px);overflow:hidden}.filter-sidebar{width:220px;min-width:220px;border-right:1px solid #e0e0e0;background:#fff;overflow-y:auto;padding:1rem}.filter-sidebar__section{margin-bottom:1.5rem}.filter-sidebar__title{font-size:.8rem;text-transform:uppercase;color:#888;margin-bottom:.5rem;font-weight:600}.filter-sidebar__item{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;cursor:pointer;font-size:.85rem}.filter-sidebar__item input[type=checkbox]{cursor:pointer}.compact-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f5f5f5}.compact-toolbar{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.compact-toolbar__select-all{display:flex;align-items:center;gap:.4rem;font-size:.85rem;cursor:pointer;color:#555}.compact-toolbar__count{font-size:.85rem;color:#1976d2;font-weight:500}.compact-toolbar__delete{margin-left:auto;padding:.4rem 1rem;background:#c0392b;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.compact-toolbar__delete:hover{background:#a93226}.compact-toolbar__delete:disabled{opacity:.4;cursor:not-allowed}.compact-toolbar__export{margin-left:.5rem;padding:.4rem 1rem;background:#302929;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.compact-toolbar__export:hover{background:#16213e}.compact-toolbar__export:disabled{opacity:.4;cursor:not-allowed}.compact-grid-wrapper{flex:1;overflow-y:auto;padding:1rem}.compact-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.compact-card{background:#fff;border-radius:6px;border:1px solid #e0e0e0;padding:.5rem;position:relative;cursor:pointer;transition:border-color .15s,box-shadow .15s}.compact-card:hover{border-color:#bbb}.compact-card--checked{border-color:#1976d2;box-shadow:0 0 0 1px #1976d2}.compact-card__checkbox{position:absolute;top:.75rem;right:.75rem;z-index:1;cursor:pointer}.compact-card__checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.compact-card__thumb{width:100%;aspect-ratio:1;border-radius:4px;overflow:hidden;background:#f0f0f0;margin-bottom:.4rem}.compact-card__thumb img{width:100%;height:100%;object-fit:cover}.compact-card__title{font-size:.8rem;font-weight:500;color:#333;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-height:1.3}.compact-card__meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-top:.2rem;font-size:.75rem;color:#888}.compact-pagination{padding:.75rem;border-top:1px solid #e0e0e0;background:#fff;flex-shrink:0}.compact-pagination .pagination{margin-top:0}.settings-page{max-width:600px;margin:2rem auto;padding:0 1.5rem}.settings-page h2{margin-bottom:1.5rem;font-size:1.5rem}.settings-section{margin-bottom:1.5rem;padding:1rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px}.settings-section h3{margin:0 0 .75rem;font-size:1rem;color:#555}.settings-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.settings-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.settings-row{display:flex;gap:1rem}.settings-label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:#555;flex:1}.settings-label input[type=number]{padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:.9rem;width:100%;box-sizing:border-box}.settings-actions{display:flex;align-items:center;gap:1rem}.btn-save-settings{background:#1976d2;color:#fff;border:none;border-radius:4px;padding:.6rem 1.5rem;font-size:.9rem;cursor:pointer;transition:background .2s}.btn-save-settings:hover{background:#1565c0}.btn-save-settings:disabled{background:#90caf9;cursor:default}.settings-message{font-size:.85rem;color:#43a047}.image-context-menu{position:fixed;z-index:1000;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:160px;padding:4px 0;font-size:.85rem}.image-context-menu__item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s;border:none;background:none;width:100%;text-align:left;font-size:.85rem}.image-context-menu__item:hover{background:#f0f0f0}.image-context-menu__thumb{width:24px;height:24px;object-fit:cover;border-radius:4px}.image-context-menu__color-dot{width:16px;height:16px;border-radius:50%;background:#ccc;flex-shrink:0}.image-context-menu__divider{height:1px;background:#eee;margin:4px 0}.image-context-menu__item--remove{color:#999}.extension-page{padding:2rem}.extension-page__inner{max-width:600px;display:flex;flex-direction:column;gap:1.5rem}.extension-page h2{font-size:1.4rem;font-weight:600}.extension-page__desc{color:#555;line-height:1.6}.btn-download-ext{align-self:flex-start;padding:.65rem 1.4rem;background:#302929;color:#fff;border:none;border-radius:6px;font-size:.95rem;cursor:pointer}.btn-download-ext:hover{background:#16213e}.ext-steps h3{font-size:1rem;font-weight:600;margin-bottom:.75rem}.ext-steps ol{padding-left:1.4rem;display:flex;flex-direction:column;gap:.6rem;line-height:1.6}.ext-steps code{background:#f0f0f0;padding:.1em .4em;border-radius:3px;font-size:.9em;font-family:monospace}.ext-note{font-size:.85rem;color:#777;border-left:3px solid #ddd;padding-left:.75rem}
