:root{color-scheme:light;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f5f6f8;color:#1f2937}.shell{max-width:1200px;margin:48px auto;padding:24px;border:1px solid #d1d5db;border-radius:12px;background:#fff}h1{margin:0 0 16px;font-size:2rem;font-weight:600}p{margin:0;font-size:1rem}.mode-banner{margin-bottom:16px;padding:10px 12px;border-radius:8px;font-size:.9rem}.mode-banner-developer{border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a}.mode-banner-client{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534}.catalog-summary{margin-bottom:16px}.category-nav,.subcategory-chips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px}.subcategory-chips{margin-top:-8px}.filters-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:0 0 16px;padding:12px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc}.field{display:grid;gap:6px}.field-label{font-size:.8125rem;color:#334155}.field input,.field select{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;font-size:.875rem;background:#fff}.checkbox-field{display:inline-flex;align-items:center;gap:8px;font-size:.875rem}.reset-button{border:1px solid #cbd5e1;border-radius:8px;background:#fff;padding:8px 10px;font-size:.875rem;cursor:pointer}.reset-button:hover{background:#f1f5f9}.chip{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#1f2937;font-size:.875rem;line-height:1;padding:8px 12px;cursor:pointer}.chip:hover{background:#f8fafc}.chip-active{background:#e2e8f0;border-color:#94a3b8}.chip-warning{color:#7c2d12;border-color:#fdba74;background:#fff7ed}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.photo-card{border:1px solid #d1d5db;border-radius:10px;overflow:hidden;background:#fff}.photo-card-button{display:block;width:100%;border:0;padding:0;text-align:left;background:transparent;cursor:pointer}.photo-card-media{position:relative;aspect-ratio:4 / 3;background:#e5e7eb}.photo-card-image{width:100%;height:100%;object-fit:cover;display:block}.photo-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#4b5563;font-size:.875rem}.photo-card-body{padding:10px 12px 12px;display:grid;gap:8px}.photo-name{font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-group{font-size:.8125rem;color:#4b5563}.quality-badge,.publish-status-badge,.warning-badge,.deployed-badge{display:inline-block;border-radius:999px;font-size:.75rem;line-height:1;padding:5px 8px}.quality-badge{border:1px solid #cbd5e1;background:#f8fafc}.quality-a{background:#dcfce7;border-color:#86efac;color:#14532d}.quality-b{background:#fef3c7;border-color:#fcd34d;color:#78350f}.quality-c{background:#e5e7eb;border-color:#cbd5e1;color:#374151}.quality-d{background:#fee2e2;border-color:#fca5a5;color:#7f1d1d}.publish-status-badge{position:absolute;top:8px;left:8px;background:#111827d9;color:#fff}.deployed-badge{position:absolute;right:8px;top:8px;background:#dcfce7;color:#14532d;border:1px solid #86efac}.warning-badge{position:absolute;right:8px;bottom:8px;background:#fff7ed;color:#9a3412;border:1px solid #fdba74}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.photo-detail-modal{width:min(1120px,100%);max-height:95vh;overflow:hidden;border-radius:12px;background:#fff;border:1px solid #cbd5e1;display:grid;grid-template-rows:auto 1fr}.photo-detail-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e2e8f0}.photo-detail-header h2{margin:0;font-size:1.125rem}.modal-close{border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#1f2937;padding:4px 8px;cursor:pointer}.photo-detail-content{display:grid;grid-template-columns:1fr;overflow:hidden}.photo-detail-image-pane{position:relative;background:#e2e8f0;min-height:220px}.photo-detail-image{width:100%;height:100%;max-height:70vh;object-fit:contain;display:block}.photo-detail-image-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#334155;font-size:.9375rem}.photo-detail-fields-pane{overflow:auto;padding:12px}.field-groups{display:grid;gap:12px}.field-group{border:1px solid #e2e8f0;border-radius:10px;padding:10px;background:#f8fafc}.field-group h3{margin:0 0 8px;font-size:.95rem}.field-group dl{margin:0;display:grid;gap:8px}.field-item{display:grid;gap:4px}.field-item-label{font-size:.75rem;color:#475569}.field-item-value{margin:0;font-size:.875rem;color:#0f172a;display:flex;gap:8px;align-items:flex-start;justify-content:space-between}.field-item-value-pre span{white-space:pre-wrap;word-break:break-word}.copy-button{border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#334155;font-size:.75rem;padding:2px 6px;cursor:pointer;flex-shrink:0}@media (min-width: 960px){.photo-detail-content{grid-template-columns:1fr 420px}.photo-detail-image{max-height:calc(95vh - 58px)}}.modal-header-actions{display:inline-flex;align-items:center;gap:8px}.nav-button{border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#1f2937;padding:4px 8px;cursor:pointer}.nav-button:disabled{opacity:.5;cursor:not-allowed}.photo-not-found{padding:24px 16px;font-size:1rem;color:#334155}.site-deploy-info{font-size:.875rem;color:#0f172a}
