*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#111827;background:#f3f4f6}button{font-family:inherit}.spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem}.spinner{width:28px;height:28px;border:3px solid #d7dbe0;border-top-color:#2f6df6;border-radius:50%;animation:spin .7s linear infinite}.spinner-label{font-size:.85rem;color:#6b7280}@keyframes spin{to{transform:rotate(360deg)}}.admin-root{display:flex;flex-direction:column;min-height:100vh}.admin-header{display:flex;flex-direction:row;align-items:center;gap:2rem;padding:0 1.5rem;height:56px;background:#111827;color:#fff}.admin-brand{font-weight:600}.admin-nav{display:flex;flex-direction:row;gap:1.2rem}.admin-nav a{color:#9ca3af;text-decoration:none;font-size:.9rem}.admin-nav a.active{color:#fff}.admin-user{display:flex;flex-direction:row;align-items:center;gap:.8rem;margin-left:auto;font-size:.85rem;color:#d1d5db}.admin-user button{border:1px solid #374151;background:transparent;color:#d1d5db;padding:.35rem .7rem;border-radius:6px;cursor:pointer}.admin-user button:hover{background:#1f2937}.admin-main{flex:1;padding:1.5rem;background:#f3f4f6}.login-container{display:flex;flex-direction:row;align-items:center;justify-content:center;min-height:100vh;background:#f3f4f6}.login-form{display:flex;flex-direction:column;gap:1.1rem;width:340px;padding:2rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 6px 24px #1118270f}.login-form h1{margin:0;font-size:1.3rem;text-align:center}.login-row{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;color:#374151}.login-row input{height:40px;padding:0 .7rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem}.login-row input:focus{outline:none;border-color:#2f6df6}.login-error{margin:0;color:#dc2626;font-size:.85rem}.login-form button{height:42px;border:none;border-radius:8px;background:#2f6df6;color:#fff;font-size:.95rem;cursor:pointer}.login-form button:disabled{opacity:.6;cursor:default}.products-page{display:flex;flex-direction:column;gap:1rem}.products-toolbar{display:flex;flex-direction:row;align-items:center;gap:1rem}.products-toolbar h2{margin:0;font-size:1.2rem}.products-toolbar input{margin-left:auto;width:320px;height:38px;padding:0 .7rem;border:1px solid #d1d5db;border-radius:8px}.products-toolbar input:focus{outline:none;border-color:#2f6df6}.products-error{color:#dc2626}.products-empty{color:#6b7280}.products-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.products-table th,.products-table td{text-align:left;padding:.7rem .9rem;font-size:.9rem;border-bottom:1px solid #f0f1f3}.products-table th{background:#f9fafb;color:#6b7280;font-weight:500}.product-link{color:#2f6df6;text-decoration:none;font-weight:500}.product-link:hover{text-decoration:underline}.btn-danger{border:1px solid #fecaca;background:#fff;color:#dc2626;padding:.3rem .6rem;border-radius:6px;cursor:pointer}.btn-danger:hover{background:#fef2f2}.products-pagination{display:flex;flex-direction:row;align-items:center;gap:1rem;font-size:.85rem;color:#6b7280}.products-pagination button{width:34px;height:34px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer}.products-pagination button:disabled{opacity:.5;cursor:default}.gallery-empty{color:#9ca3af;font-size:.85rem;padding:.5rem 0}.gallery-grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:.6rem}.gallery-thumb{position:relative;width:110px;height:110px;padding:0;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#f9fafb;cursor:pointer}.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.gallery-thumb:hover{border-color:#2f6df6}.gallery-thumb-tag{position:absolute;left:0;bottom:0;right:0;padding:.15rem .35rem;font-size:.65rem;color:#fff;background:#111827a6;text-align:left}.lightbox{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:row;align-items:center;justify-content:center;background:#111827e0}.lightbox-figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:.6rem;max-width:90vw;max-height:90vh}.lightbox-figure img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:6px}.lightbox-figure figcaption{color:#d1d5db;font-size:.85rem}.lightbox-close{position:absolute;top:1rem;right:1.25rem;width:40px;height:40px;border:none;border-radius:50%;background:#ffffff1a;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer}.lightbox-close:hover{background:#fff3}.lightbox-nav{width:52px;height:52px;margin:0 .5rem;border:none;border-radius:50%;background:#ffffff1a;color:#fff;font-size:2rem;line-height:1;cursor:pointer}.lightbox-nav:hover{background:#fff3}.product-detail{display:flex;flex-direction:column;gap:1.25rem;max-width:960px}.detail-error{color:#dc2626}.detail-muted{color:#9ca3af}.detail-back a{color:#2f6df6;text-decoration:none;font-size:.85rem}.detail-head{display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;gap:1rem}.detail-head h2{margin:0 0 .5rem;font-size:1.5rem}.detail-meta{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;gap:.5rem}.detail-id{font-size:.75rem;color:#9ca3af}.detail-dates{font-size:.78rem;color:#6b7280;text-align:right;white-space:nowrap}.chip{display:inline-block;padding:.12rem .5rem;border-radius:999px;font-size:.72rem;background:#eef2f7;color:#374151}.chip-tag{background:#e0edff;color:#1d4ed8}.chip-muted{background:#fde8e8;color:#b91c1c}.detail-section{display:flex;flex-direction:column;gap:.6rem;padding:1rem 1.1rem;background:#fff;border:1px solid #e5e7eb;border-radius:10px}.detail-section h3{margin:0;font-size:1rem;color:#374151}.detail-webtitle{margin:0;font-weight:500}.detail-short{margin:0;color:#4b5563}.detail-html{font-size:.9rem;line-height:1.55;color:#374151}.detail-html img{max-width:100%}.spec-table{width:100%;border-collapse:collapse}.spec-table td{padding:.4rem .6rem;font-size:.86rem;border-bottom:1px solid #f0f1f3;vertical-align:top}.spec-table .spec-label{color:#6b7280;width:45%}.variant-list{display:flex;flex-direction:column;gap:.8rem}.variant-card{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.variant-card.inactive{opacity:.75}.variant-head{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:.8rem;padding:.7rem .9rem;background:#f9fafb;cursor:pointer}.variant-title{display:flex;flex-direction:row;align-items:center;gap:.6rem}.variant-toggle{color:#9ca3af}.variant-article{font-size:.78rem;color:#6b7280;background:#eef2f7;padding:.1rem .45rem;border-radius:5px}.variant-flags{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;gap:.35rem}.variant-body{display:flex;flex-direction:column;gap:.8rem;padding:.9rem}.variant-props{display:flex;flex-direction:row;flex-wrap:wrap;gap:1.2rem}.prop{display:flex;flex-direction:column;gap:.15rem;font-size:.86rem}.prop-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:#9ca3af}.variant-short{margin:0;font-size:.86rem;color:#4b5563}.variant-equip{display:flex;flex-direction:column;gap:.35rem}.variant-equip ul{margin:0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.3rem}.variant-equip li{display:flex;flex-direction:row;align-items:center;gap:.5rem;font-size:.85rem}.equip-qty{color:#6b7280;margin-left:auto}.variant-prov{font-size:.75rem;color:#9ca3af}.compat-list{margin:0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.4rem}.compat-list li{display:flex;flex-direction:row;align-items:center;gap:.6rem;font-size:.88rem}.compat-list li a{color:#2f6df6;text-decoration:none}.sync-page{display:flex;flex-direction:column;gap:1rem}.sync-toolbar{display:flex;flex-direction:row;align-items:center;gap:1rem}.sync-toolbar h2{margin:0;font-size:1.2rem}.sync-toolbar input{margin-left:auto;width:300px;height:38px;padding:0 .7rem;border:1px solid #d1d5db;border-radius:8px}.sync-toolbar input:focus{outline:none;border-color:#2f6df6}.btn-sync{height:38px;padding:0 1rem;border:none;border-radius:8px;background:#2f6df6;color:#fff;cursor:pointer}.btn-sync:disabled{opacity:.5;cursor:default}.sync-error{color:#dc2626}.sync-empty{color:#6b7280}.sync-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.sync-table th,.sync-table td{text-align:left;padding:.6rem .9rem;font-size:.88rem;border-bottom:1px solid #f0f1f3;vertical-align:top}.sync-table th{background:#f9fafb;color:#6b7280;font-weight:500}.sync-table .row-selected{background:#f5f8ff}.sync-articles{color:#6b7280;max-width:260px}.badge{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.75rem;font-weight:500}.badge.badge-new{background:#e0edff;color:#1d4ed8}.badge.badge-outdated{background:#fff0d9;color:#b45309}.badge.badge-synced{background:#def7e5;color:#15803d}.sync-pagination{display:flex;flex-direction:row;align-items:center;gap:1rem;font-size:.85rem;color:#6b7280}.sync-pagination button{width:34px;height:34px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer}.sync-pagination button:disabled{opacity:.5;cursor:default}.sync-results{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px}.sync-results .sync-results-head{display:flex;flex-direction:row;align-items:center;justify-content:space-between}.sync-results .sync-results-head button{border:none;background:transparent;font-size:1.3rem;line-height:1;cursor:pointer;color:#6b7280}.sync-results ul{margin:0;padding-left:1rem}.sync-results li{font-size:.85rem;margin-bottom:.3rem}.sync-results .res-name{margin-right:.5rem}.sync-results .res-tag.ok{color:#15803d}.sync-results .res-tag.err{color:#dc2626}.sync-results .res-warnings{list-style:none;padding-left:.5rem;color:#b45309}
