.skill-center { height: 100%; min-height: 0; } .skill-view-enter-active, .skill-view-leave-active { transition: opacity 220ms ease, transform 300ms var(--ease); } .skill-view-enter-from, .skill-view-leave-to { opacity: 0; transform: translateY(14px); } .skill-list, .skill-detail { height: 100%; min-height: 0; } .skill-detail { display: grid; grid-template-rows: minmax(0, 1fr) auto; gap: 12px; } .skill-list { display: flex; flex-direction: column; min-height: 0; padding: 18px 20px; overflow: hidden; } .status-tabs { display: flex; gap: 18px; padding-bottom: 12px; border-bottom: 1px solid #edf2f7; } .status-tabs button { position: relative; border: 0; background: transparent; color: #64748b; font-size: 14px; font-weight: 760; } .status-tabs button.active { color: #0f172a; } .status-tabs button.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -13px; height: 3px; border-radius: 999px; background: #10b981; } .list-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 0 10px; } .filter-set { display: flex; align-items: center; gap: 10px; flex: 1 1 auto; flex-wrap: wrap; } .search-filter { width: 280px; min-height: 38px; display: inline-flex; align-items: center; gap: 8px; padding: 0 11px; border: 1px solid #d7e0ea; border-radius: 8px; background: #fff; color: #64748b; } .search-filter i { color: #94a3b8; font-size: 16px; } .search-filter input { width: 100%; min-width: 0; border: 0; outline: 0; background: transparent; color: #0f172a; font-size: 13px; } .search-filter input::placeholder { color: #94a3b8; } .search-filter:focus-within { border-color: rgba(16, 185, 129, 0.48); box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1); } .picker-trigger, .ghost-filter-btn, .create-btn, .row-action { min-height: 38px; border-radius: 8px; font-size: 13px; font-weight: 760; } .picker-filter { position: relative; } .picker-trigger { min-width: 124px; display: inline-flex; align-items: center; justify-content: space-between; gap: 8px; padding: 0 34px 0 12px; border: 1px solid #d7e0ea; background: #fff; color: #334155; white-space: nowrap; } .picker-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .picker-trigger .mdi { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); color: #64748b; pointer-events: none; } .picker-trigger:hover, .picker-filter.open .picker-trigger { border-color: rgba(16, 185, 129, 0.34); background: #f6fffb; color: #0f9f78; } .picker-popover { position: absolute; top: calc(100% + 8px); left: 0; width: 224px; z-index: 40; display: grid; gap: 14px; padding: 16px; border: 1px solid #d7e0ea; border-radius: 12px; background: #fff; box-shadow: 0 18px 42px rgba(15, 23, 42, 0.16); } .picker-popover header { display: flex; align-items: center; justify-content: space-between; gap: 12px; } .picker-popover header strong { color: #0f172a; font-size: 15px; } .picker-popover header button { width: 30px; height: 30px; display: grid; place-items: center; border: 0; border-radius: 8px; background: transparent; color: #64748b; } .picker-popover header button:hover { background: #f1f5f9; color: #0f172a; } .picker-option-list { display: grid; gap: 8px; max-height: 240px; overflow-y: auto; } .picker-option { min-height: 36px; display: inline-flex; align-items: center; padding: 0 12px; border: 1px solid #d7e0ea; border-radius: 8px; background: #fff; color: #334155; font-size: 13px; font-weight: 750; text-align: left; } .picker-option:hover, .picker-option.active { border-color: rgba(16, 185, 129, 0.32); background: rgba(16, 185, 129, 0.08); color: #059669; } .toolbar-actions { display: flex; align-items: center; gap: 10px; } .ghost-filter-btn { display: inline-flex; align-items: center; gap: 8px; padding: 0 12px; border: 1px solid #d7e0ea; background: #fff; color: #475569; } .ghost-filter-btn:hover { border-color: rgba(16, 185, 129, 0.28); color: #059669; } .create-btn { display: inline-flex; align-items: center; gap: 8px; padding: 0 14px; border: 0; background: #059669; color: #fff; box-shadow: 0 8px 18px rgba(5, 150, 105, 0.18); } .create-btn:disabled { background: #cbd5e1; color: #f8fafc; box-shadow: none; cursor: not-allowed; } .hint { display: inline-flex; align-items: center; gap: 6px; margin: 0 0 12px; color: #64748b; font-size: 12px; } .hint .mdi { color: #94a3b8; } .active-filter-strip { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; } .active-filter-chip { min-height: 28px; display: inline-flex; align-items: center; padding: 0 10px; border-radius: 999px; background: rgba(16, 185, 129, 0.1); color: #047857; font-size: 12px; font-weight: 800; } .table-wrap { flex: 1 1 auto; position: relative; min-height: 400px; overflow: auto; border: 1px solid #edf2f7; border-radius: 12px; background: linear-gradient(180deg, #fcfefd 0%, #f4f8f6 100%); display: flex; flex-direction: column; align-items: stretch; justify-content: flex-start; } .table-wrap.is-empty { align-items: center; justify-content: center; } .table-wrap table { width: 100%; align-self: flex-start; } .table-state, .detail-inline-state { width: 100%; min-height: 220px; display: grid; place-items: center; gap: 12px; padding: 28px 24px; text-align: center; color: #64748b; align-self: center; } .detail-inline-state { min-height: 180px; display: flex; align-items: center; justify-content: space-between; gap: 16px; text-align: left; } .table-state i, .detail-inline-state i { font-size: 28px; color: #94a3b8; } .table-state.error i, .detail-inline-state.error i { color: #dc2626; } .table-state.empty i { color: #0ea5e9; } .table-state p, .detail-inline-state p { margin-top: 6px; font-size: 13px; line-height: 1.6; } .detail-inline-state strong { color: #0f172a; font-size: 14px; font-weight: 850; } .detail-inline-state > div { flex: 1 1 auto; } .state-action { height: 36px; display: inline-flex; align-items: center; justify-content: center; padding: 0 14px; border: 1px solid rgba(16, 185, 129, 0.28); border-radius: 8px; background: #fff; color: #059669; font-size: 13px; font-weight: 760; } .list-foot { display: flex; align-items: center; justify-content: flex-end; padding-top: 12px; } .page-summary { color: #64748b; font-size: 12px; font-weight: 700; } table { width: 100%; min-width: 1120px; border-collapse: collapse; } th, td { padding: 14px 12px; border-bottom: 1px solid #edf2f7; text-align: center; vertical-align: middle; color: #334155; font-size: 12px; } th { background: #f8fafc; color: #64748b; font-weight: 800; white-space: nowrap; } tbody tr { cursor: pointer; transition: background 180ms ease; } th:first-child, td:first-child { text-align: left; } tbody tr:hover { background: #f8fbff; } tbody tr.spotlight { background: linear-gradient(90deg, rgba(16, 185, 129, 0.05), rgba(59, 130, 246, 0.03)); } .skill-name-cell { display: grid; grid-template-columns: 38px minmax(0, 1fr); gap: 10px; align-items: center; } .skill-avatar { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 11px; color: #fff; font-size: 13px; font-weight: 900; } .skill-avatar.emerald { background: linear-gradient(135deg, #10b981, #059669); } .skill-avatar.violet { background: linear-gradient(135deg, #8b5cf6, #7c3aed); } .skill-avatar.blue { background: linear-gradient(135deg, #3b82f6, #2563eb); } .skill-avatar.amber { background: linear-gradient(135deg, #f59e0b, #ea580c); } .skill-name-cell strong { display: block; color: #0f172a; font-size: 13px; font-weight: 850; } .skill-name-cell span:last-child { display: block; margin-top: 4px; color: #64748b; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .scope-pill, .status-pill { display: inline-flex; align-items: center; justify-content: center; min-height: 26px; padding: 0 9px; border-radius: 999px; font-size: 11px; font-weight: 800; white-space: nowrap; } .scope-pill { background: #f1f5f9; color: #475569; } .status-pill.success { background: #dcfce7; color: #059669; } .status-pill.warning { background: #fff7ed; color: #ea580c; } .status-pill.draft { background: #eef2ff; color: #6366f1; } .status-pill.danger { background: #fee2e2; color: #dc2626; } .status-pill.disabled { background: #e2e8f0; color: #475569; } .row-action { padding: 0 12px; border: 1px solid rgba(16, 185, 129, 0.32); background: #fff; color: #059669; } .row-action:hover { background: rgba(16, 185, 129, 0.08); } .detail-scroll { height: 100%; overflow: auto; display: grid; align-content: start; gap: 16px; } .detail-hero { display: grid; grid-template-columns: minmax(0, 1fr) 320px; align-items: start; gap: 10px; padding: 16px 20px; } .hero-title { min-width: 0; } .skill-badge { display: inline-flex; align-items: center; min-height: 24px; padding: 0 8px; border-radius: 999px; color: #fff; font-size: 11px; font-weight: 800; } .skill-badge.emerald { background: linear-gradient(135deg, #10b981, #059669); } .skill-badge.violet { background: linear-gradient(135deg, #8b5cf6, #7c3aed); } .skill-badge.blue { background: linear-gradient(135deg, #3b82f6, #2563eb); } .skill-badge.amber { background: linear-gradient(135deg, #f59e0b, #ea580c); } .hero-title h2 { margin-top: 10px; color: #0f172a; font-size: 24px; font-weight: 850; } .hero-title p { margin-top: 8px; max-width: 820px; color: #64748b; font-size: 14px; line-height: 1.6; } .hero-review-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 12px; } .inline-review-meta { margin-top: 10px; } .review-note-block { display: grid; gap: 6px; margin-top: 12px; padding: 12px 14px; border: 1px solid rgba(16, 185, 129, 0.16); border-radius: 12px; background: linear-gradient(180deg, #f8fffc, #ffffff); } .review-note-block strong { color: #0f172a; font-size: 13px; font-weight: 850; } .review-note-block p, .review-note-block span { color: #64748b; font-size: 12px; line-height: 1.6; } .review-note-block.muted { border-color: #e2e8f0; background: #f8fafc; } .hero-review-meta span { display: inline-flex; align-items: center; gap: 5px; min-height: 26px; padding: 0 9px; border-radius: 999px; background: #f8fafc; color: #475569; font-size: 12px; font-weight: 800; } .hero-review-meta i { color: #059669; font-size: 15px; } .hero-stats { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; } .hero-stat { min-height: 54px; display: grid; align-content: center; gap: 4px; padding: 9px 12px; border-radius: 10px; background: #f8fafc; border: 1px solid #e5eaf0; } .hero-stat span { display: block; color: #64748b; font-size: 11px; font-weight: 800; line-height: 1.2; } .hero-stat strong { display: block; color: #0f172a; font-size: 15px; font-weight: 850; line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .hero-stat .status-pill { width: fit-content; min-height: 22px; padding: 0 8px; } .detail-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.78fr); gap: 16px; } .detail-grid.skill-md-detail-grid { grid-template-columns: minmax(0, 1fr) 372px; align-items: stretch; } .detail-grid.skill-md-detail-grid .detail-main { height: 100%; } .detail-main, .detail-side { display: grid; gap: 16px; align-content: start; } .detail-card, .side-card { padding: 18px; } .card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 16px; } .card-head h3 { color: #0f172a; font-size: 16px; font-weight: 850; } .card-head p { margin-top: 6px; color: #64748b; font-size: 13px; line-height: 1.5; } .edit-badge { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; background: #ecfeff; color: #0891b2; font-size: 12px; font-weight: 800; } .form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; } .field { display: grid; gap: 7px; } .field.span-2 { grid-column: span 2; } .field span { color: #64748b; font-size: 12px; font-weight: 800; } .field input, .field textarea, .prompt-block textarea { width: 100%; border: 1px solid #d7e0ea; border-radius: 10px; background: #fff; color: #0f172a; font-size: 13px; line-height: 1.55; padding: 10px 12px; resize: vertical; } .field input[readonly], .field textarea[readonly], .prompt-block textarea[readonly] { background: #f8fafc; color: #334155; } .markdown-card { min-height: 620px; display: grid; grid-template-rows: auto minmax(0, 1fr); } .json-editor-card { display: grid; gap: 12px; } .markdown-card .field { min-height: 0; grid-template-rows: auto minmax(0, 1fr); } .markdown-editor { min-height: 520px; height: 100%; font-family: "Cascadia Mono", "Consolas", monospace; font-size: 13px; line-height: 1.65; white-space: pre; } .markdown-editor.disabled { background: #f8fafc; color: #475569; } .json-template-meta { display: flex; gap: 10px; flex-wrap: wrap; } .json-template-meta span { min-height: 28px; display: inline-flex; align-items: center; gap: 6px; padding: 0 10px; border-radius: 999px; background: #f8fafc; color: #475569; font-size: 12px; font-weight: 750; } .json-template-meta strong { color: #0f172a; font-weight: 850; } .json-editor { min-height: 320px; font-family: "Cascadia Mono", "Consolas", monospace; font-size: 13px; line-height: 1.65; white-space: pre; } .json-editor.disabled { background: #f8fafc; color: #475569; } .subtle-banner, .editor-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; } .subtle-banner { min-height: 38px; margin-bottom: 10px; padding: 0 12px; border: 1px solid #e0f2fe; border-radius: 10px; background: #f0f9ff; color: #0369a1; font-size: 12px; font-weight: 700; } .editor-foot { margin-top: 12px; color: #64748b; font-size: 12px; line-height: 1.5; } .skill-review-side { align-content: start; padding-right: 8px; } .review-card { position: sticky; top: 0; } .reviewer-card { border-color: rgba(16, 185, 129, 0.24); background: linear-gradient(180deg, #ffffff, #f8fffc); } .review-list { display: grid; gap: 0; } .review-row { display: grid; gap: 6px; padding: 12px 0; border-top: 1px solid #edf2f7; } .review-row:first-child { border-top: 0; padding-top: 0; } .review-row span { color: #64748b; font-size: 12px; font-weight: 800; } .review-row strong { color: #0f172a; font-size: 13px; font-weight: 850; line-height: 1.45; } .version-list { display: grid; gap: 0; } .version-row { display: grid; gap: 6px; width: 100%; padding: 10px 12px; border-top: 1px solid #edf2f7; border-right: 0; border-bottom: 0; border-left: 0; background: transparent; text-align: left; cursor: pointer; transition: background 180ms ease; } .version-row:first-child { border-top: 0; } .version-row:hover { border-radius: 10px; background: #f8fafc; } .version-row.active { border-radius: 10px; background: rgba(16, 185, 129, 0.08); } .version-row-head { display: grid; grid-template-columns: minmax(52px, 1fr) 46px 82px; align-items: center; gap: 8px; } .version-row strong { color: #0f172a; font-size: 13px; font-weight: 850; } .version-row span { color: #94a3b8; font-size: 11px; font-weight: 800; white-space: nowrap; text-align: right; } .version-current-slot { min-width: 46px; display: grid; place-items: center; text-align: center; } .version-current-slot .current-version { min-height: 20px; display: inline-flex; align-items: center; justify-content: center; padding: 0 7px; border-radius: 999px; background: #dcfce7; color: #059669; font-size: 11px; font-weight: 850; } .version-row p { color: #64748b; font-size: 12px; line-height: 1.5; } .empty-side-note { min-height: 120px; display: grid; place-items: center; gap: 8px; color: #64748b; font-size: 13px; text-align: center; } .empty-side-note i { font-size: 24px; color: #94a3b8; } .version-modal-summary { display: grid; grid-template-columns: minmax(0, 1fr) 28px minmax(0, 1fr); align-items: center; gap: 10px; margin-top: 4px; } .version-modal-summary div { padding: 12px; border: 1px solid #edf2f7; border-radius: 10px; background: #f8fafc; } .version-modal-summary span, .version-modal-note span { display: block; color: #64748b; font-size: 12px; font-weight: 800; } .version-modal-summary strong, .version-modal-note strong { display: block; margin-top: 6px; color: #0f172a; font-size: 15px; font-weight: 850; } .version-modal-summary i { color: #94a3b8; text-align: center; } .version-modal-note { margin-top: 12px; padding: 12px; border: 1px solid #edf2f7; border-radius: 10px; background: #fff; } .prompt-stack { display: grid; gap: 14px; } .prompt-block { padding: 14px; border: 1px solid #edf2f7; border-radius: 12px; background: #fbfdff; } .prompt-block header { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; } .prompt-block strong { color: #0f172a; font-size: 14px; font-weight: 850; } .prompt-block header span { color: #64748b; font-size: 12px; font-weight: 700; } .contract-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; } .contract-panel { padding: 14px; border: 1px solid #edf2f7; border-radius: 12px; background: #fbfdff; } .contract-panel h4 { margin: 0 0 10px; color: #0f172a; font-size: 14px; font-weight: 850; } .contract-panel ul { display: grid; gap: 8px; margin: 0; padding-left: 18px; color: #475569; font-size: 13px; line-height: 1.6; } .test-row, .tool-row, .history-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; padding: 12px 0; border-top: 1px solid #edf2f7; } .test-row:first-child, .tool-row:first-child, .history-row:first-child { border-top: 0; padding-top: 0; } .test-row strong, .tool-row strong, .history-row strong { display: block; color: #0f172a; font-size: 13px; font-weight: 800; } .test-row span, .tool-row span, .history-row span, .history-row small { display: block; margin-top: 4px; color: #64748b; font-size: 12px; line-height: 1.5; } .test-state, .tool-state { display: inline-flex; align-items: center; min-height: 24px; padding: 0 8px; border-radius: 999px; font-size: 11px; font-weight: 800; white-space: nowrap; } .test-state.success, .tool-state.safe { background: #dcfce7; color: #059669; } .test-state.warning, .tool-state.active { background: #fff7ed; color: #ea580c; } .test-state.danger, .tool-state.danger { background: #fee2e2; color: #dc2626; } .review-action-strip { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; } .action-help { margin-top: 12px; color: #64748b; font-size: 12px; line-height: 1.6; } .tag-list { display: flex; gap: 8px; flex-wrap: wrap; } .tag-list span { min-height: 28px; display: inline-flex; align-items: center; padding: 0 10px; border-radius: 999px; background: #eff6ff; color: #2563eb; font-size: 12px; font-weight: 800; } .publish-card { display: grid; gap: 14px; } .publish-card p, .publish-summary span { margin-top: 6px; color: #64748b; font-size: 13px; line-height: 1.55; } .publish-summary { display: flex; align-items: center; justify-content: space-between; gap: 12px; min-height: 42px; padding: 0 12px; border-radius: 10px; background: #f8fafc; } .publish-summary strong { color: #059669; font-size: 14px; font-weight: 850; } .detail-actions { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 0 0; border-top: 1px solid #e5eaf0; } .detail-action-group { display: flex; justify-content: flex-end; gap: 8px; } .back-action, .minor-action, .major-action { height: 38px; display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 0 14px; border-radius: 8px; font-size: 13px; font-weight: 760; } .back-action { border: 1px solid #d7e0ea; background: #fff; color: #475569; } .minor-action { border: 1px solid #d7e0ea; background: #fff; color: #334155; } .minor-action.success-action { border-color: rgba(5, 150, 105, 0.26); color: #059669; } .minor-action.danger-action { border-color: rgba(220, 38, 38, 0.2); color: #dc2626; } .major-action { border: 1px solid #059669; background: #059669; color: #fff; box-shadow: 0 4px 12px rgba(5, 150, 105, .16); } .back-action:hover, .minor-action:hover, .major-action:hover, .mini-btn:hover { transform: translateY(-1px); } .back-action:disabled, .minor-action:disabled, .major-action:disabled, .mini-btn:disabled { opacity: 0.52; cursor: not-allowed; transform: none; box-shadow: none; } .detail-meta-actions { align-items: center; } .footer-note { color: #64748b; font-size: 12px; font-weight: 700; } .mini-btn { min-height: 36px; display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 0 12px; border: 1px solid #d7e0ea; border-radius: 8px; background: #fff; color: #334155; font-size: 13px; font-weight: 760; } .mini-btn.primary { border-color: #059669; background: #059669; color: #fff; } @media (max-width: 1320px) { .detail-hero { grid-template-columns: 1fr; } .hero-stats, .form-grid, .contract-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .detail-grid { grid-template-columns: 1fr; } .detail-grid.skill-md-detail-grid { grid-template-columns: 1fr; } .skill-review-side { padding-right: 0; } .review-card { position: static; } } @media (max-width: 860px) { .skill-list, .detail-card, .side-card, .detail-hero { padding: 16px; } .list-toolbar, .card-head, .detail-actions, .detail-action-group, .toolbar-actions, .detail-inline-state { flex-direction: column; align-items: stretch; } .status-tabs, .filter-set { overflow-x: auto; } .search-filter, .picker-trigger, .picker-filter, .toolbar-actions > * { width: 100%; } .picker-popover { width: min(100vw - 64px, 320px); } .hero-stats, .form-grid, .contract-grid { grid-template-columns: 1fr; } .review-action-strip { flex-direction: column; } .version-modal-summary { grid-template-columns: 1fr; } .version-modal-summary i { transform: rotate(90deg); } .field.span-2 { grid-column: span 1; } }