* { box-sizing: border-box; margin: 0; padding: 0; }
[v-cloak] { display: none; }
body { font-family: -apple-system,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif; background: #f4f5f7; color: #222; }

.login-box { max-width: 320px; margin: 120px auto; background: #fff; padding: 30px; border-radius: 10px; box-shadow: 0 2px 14px rgba(0,0,0,.08); display: flex; flex-direction: column; gap: 10px; }
.login-box input { padding: 10px; border: 1px solid #ddd; border-radius: 6px; }
.login-box button { padding: 10px; background: #2b2620; color: #fff; border: none; border-radius: 6px; cursor: pointer; }
.err { color: #c0392b; font-size: 13px; }

.admin-shell { display: flex; min-height: 100vh; }
.sidebar { width: 200px; background: #1f1b16; color: #f2e9db; display: flex; flex-direction: column; padding: 20px 0; }
.sidebar .logo { font-size: 16px; font-weight: 700; padding: 0 20px 20px; }
.sidebar nav { flex: 1; display: flex; flex-direction: column; }
.sidebar nav button { text-align: left; background: none; border: none; color: #cbbfa8; padding: 12px 20px; cursor: pointer; font-size: 14px; }
.sidebar nav button.active { background: #33291c; color: #fff; }
.sidebar .logout { margin: 0 20px; padding: 10px; background: #4a3f30; color: #fff; border: none; border-radius: 6px; cursor: pointer; }

.content { flex: 1; padding: 26px 32px; overflow-x: auto; }
.content h2 { margin-bottom: 16px; }

table { width: 100%; border-collapse: collapse; background: #fff; margin-top: 12px; }
th, td { padding: 10px 12px; border-bottom: 1px solid #eee; text-align: left; font-size: 13px; }
th { background: #fafafa; }
.thumb { width: 44px; height: 44px; object-fit: contain; background: #f5f5f5; border-radius: 4px; }
.swatch { display: inline-block; width: 30px; height: 30px; border-radius: 50%; }

.add-btn { padding: 8px 16px; background: #2b2620; color: #fff; border: none; border-radius: 6px; cursor: pointer; font-size: 13px; }
table button { margin-right: 6px; padding: 4px 8px; font-size: 12px; border: 1px solid #ddd; background: #fff; border-radius: 4px; cursor: pointer; }

.settings-form { background: #fff; padding: 20px; border-radius: 8px; display: flex; flex-direction: column; gap: 6px; max-width: 480px; }
.settings-form label { font-size: 12px; color: #666; margin-top: 8px; }
.settings-form input { padding: 8px; border: 1px solid #ddd; border-radius: 6px; }

.modal-mask { position: fixed; inset: 0; background: rgba(0,0,0,.4); display: flex; align-items: center; justify-content: center; z-index: 50; }
.modal-box { background: #fff; padding: 24px; border-radius: 10px; width: 380px; max-height: 86vh; overflow-y: auto; display: flex; flex-direction: column; gap: 6px; }
.modal-box.wide { width: 620px; }
.modal-box label { font-size: 12px; color: #666; margin-top: 8px; }
.modal-box input, .modal-box select { padding: 8px; border: 1px solid #ddd; border-radius: 6px; }
.preview-img { width: 70px; height: 70px; object-fit: contain; margin-top: 6px; background: #f5f5f5; border-radius: 4px; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 16px; }
.modal-actions button { padding: 8px 16px; border-radius: 6px; border: 1px solid #ddd; background: #fff; cursor: pointer; }
.modal-actions button.primary { background: #2b2620; color: #fff; border: none; }
