.topnav{position:fixed;top:0;left:0;right:0;height:60px;background-color:#ffc600;box-shadow:0 2px 8px #ff81818a;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:1000;border-bottom:2px solid #dd1d21}.topnav__brand{display:flex;align-items:center}.topnav__logo-link{display:flex;align-items:center;text-decoration:none;color:#1a1a1a}.topnav__logo-img{height:36px;width:auto;margin-right:12px}.topnav__logo{font-size:24px;font-weight:800;letter-spacing:2px;margin-right:12px}.topnav__title{font-size:14px;font-weight:500;color:#333;border-left:2px solid #333;padding-left:12px}.topnav__actions{display:flex;align-items:center;gap:16px}.topnav__user{position:relative;display:flex;align-items:center}.topnav__user-btn{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}.topnav__user-btn:hover{background:#0000000f}.topnav__avatar{width:34px;height:34px;border-radius:50%;background-color:#1a1a1a;color:#ffc600;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}.topnav__username{font-size:13px;font-weight:600;color:#1a1a1a;white-space:nowrap}.topnav__chevron{font-size:9px;color:#555}.topnav__dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 24px #0000001f;min-width:220px;z-index:1100;overflow:hidden}.topnav__dropdown-header{padding:12px 16px}.topnav__dropdown-name{font-size:14px;font-weight:700;color:#1a1a2e}.topnav__dropdown-email{font-size:12px;color:#6b7280;margin-top:2px;word-break:break-all}.topnav__dropdown-divider{height:1px;background:#e5e7eb}.topnav__dropdown-item{display:block;width:100%;padding:10px 16px;border:none;background:none;text-align:left;font-size:13px;font-weight:500;color:#374151;cursor:pointer;transition:background .15s}.topnav__dropdown-item:hover{background:#f4f6f8}.topnav__dropdown-item--logout{color:#dc2626}.topnav__dropdown-item--logout:hover{background:#fef2f2}.sidenav{position:fixed;top:60px;left:0;bottom:0;width:240px;background-color:#fff;color:#333;display:flex;flex-direction:column;transition:width .3s cubic-bezier(.4,0,.2,1);overflow:visible;z-index:900;border-right:1px solid #e8e8e8}.sidenav--collapsed{width:72px}.sidenav__menu{display:flex;flex-direction:column;padding:12px 0;overflow-y:auto;overflow-x:hidden;flex:1}.sidenav__item{position:relative;display:flex;align-items:center;padding:14px 24px;text-decoration:none;color:#555;font-size:14px;font-weight:500;white-space:nowrap;transition:background-color .2s ease,color .2s ease;border-left:3px solid transparent}.sidenav--collapsed .sidenav__item{padding:14px 0;justify-content:center}.sidenav__item:hover{background-color:#ffc6001a;color:#dd1d21}.sidenav__item--active{background-color:#ffc60026;color:#dd1d21;font-weight:700;border-left-color:#dd1d21}.sidenav__item--active .sidenav__icon{color:#dd1d21}.sidenav--collapsed .sidenav__item--active{border-left-color:#dd1d21}.sidenav__icon{font-size:20px;min-width:24px;display:flex;align-items:center;justify-content:center}.sidenav__label{margin-left:14px;transition:opacity .3s ease}.sidenav--collapsed .sidenav__label{display:none}.sidenav__tooltip{position:absolute;left:72px;background-color:#333;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1000;box-shadow:0 2px 8px #0000004d}.sidenav--collapsed .sidenav__item:hover .sidenav__tooltip{opacity:1}.sidenav:not(.sidenav--collapsed) .sidenav__tooltip{display:none}.sidenav__toggle{position:absolute;top:12px;right:-14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0;border:1px solid #e8e8e8;border-radius:50%;background-color:#dd1d21;color:#fff;cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease;box-shadow:0 2px 4px #0000001a;z-index:1001}.sidenav__toggle:hover{background-color:#ffc600;color:#1a1a2e;border-color:#ffc600}.sidenav__toggle-icon{font-size:14px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.sidenav__group{display:flex;flex-direction:column}.sidenav__item--parent{background:none;border:none;outline:none;font-family:inherit;font-size:14px;font-weight:500;color:#555;width:100%;text-align:left;cursor:pointer;padding:14px 24px;border-left:3px solid transparent;display:flex;align-items:center;white-space:nowrap;transition:background-color .2s ease,color .2s ease}.sidenav__item--parent:hover{background-color:#ffc6001a;color:#dd1d21}.sidenav__item--parent.sidenav__item--active{background-color:#ffc60026;color:#dd1d21;font-weight:700;border-left-color:#dd1d21}.sidenav__item--parent.sidenav__item--active .sidenav__icon{color:#dd1d21}.sidenav--collapsed .sidenav__item--parent{padding:14px 0;justify-content:center}.sidenav__chevron{margin-left:auto;display:flex;align-items:center;opacity:.6}.sidenav__submenu{display:flex;flex-direction:column;background:#00000005}.sidenav__subitem{display:flex;align-items:center;padding:10px 24px 10px 52px;text-decoration:none;color:#666;font-size:13px;font-weight:500;transition:background-color .2s ease,color .2s ease}.sidenav__subitem:hover{background-color:#ffc6001a;color:#dd1d21}.sidenav__subitem--active{color:#dd1d21;font-weight:700;background-color:#ffc60014}.sidenav__subitem-dot{width:6px;height:6px;border-radius:50%;background:#ccc;margin-right:10px;flex-shrink:0}.sidenav__subitem--active .sidenav__subitem-dot{background:#dd1d21}.sidenav__subitem-label{white-space:nowrap}.sidenav--collapsed .sidenav__submenu,.sidenav--collapsed .sidenav__chevron{display:none}.layout{min-height:100vh}.layout__content{margin-top:60px;margin-left:240px;padding:16px 24px;min-height:calc(100vh - 60px);background-color:#f5f6fa;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.layout__content--expanded{margin-left:72px}.dashboard{max-width:1400px;display:flex;flex-direction:column;height:calc(100vh - 100px)}.dashboard__tabs{display:flex;gap:0;border-bottom:2px solid #eee;margin-bottom:16px;flex-shrink:0}.dashboard__tab{padding:10px 20px;border:none;background:none;font-size:14px;font-weight:600;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.dashboard__tab:hover{color:#555}.dashboard__tab--active{color:#1a1a2e;border-bottom-color:#ffc600}.dashboard__content{flex:1;overflow-y:auto}.dashboard__cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px}.dashboard__card{background:#fff;border-radius:10px;padding:16px 18px;box-shadow:0 2px 8px #0000000d;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s}.dashboard__card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000014}.dashboard__card--pinned{border:1px solid #FFC600}.dashboard__card-indicator{position:absolute;top:0;left:0;width:4px;height:100%}.dashboard__card-pin{position:absolute;top:8px;right:8px;background:none;border:none;font-size:12px;cursor:pointer;opacity:.5;transition:opacity .2s}.dashboard__card-pin:hover,.dashboard__card--pinned .dashboard__card-pin{opacity:1}.dashboard__card-content{display:flex;flex-direction:column;gap:4px}.dashboard__card-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:#888}.dashboard__card-value{font-size:26px;font-weight:700;color:#1a1a2e}.dashboard__card-trend{font-size:12px;color:#666}.dashboard__sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:16px}.dashboard__section{background:#fff;border-radius:10px;padding:18px 20px;box-shadow:0 2px 8px #0000000d}.dashboard__section-title{font-size:14px;font-weight:600;color:#1a1a2e;margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid #eee}.dashboard__chart{padding:8px 0}.dashboard__chart-bar{display:flex;height:28px;border-radius:6px;overflow:hidden;margin-bottom:12px}.dashboard__chart-segment{transition:width .3s}.dashboard__chart-legend{display:flex;flex-wrap:wrap;gap:12px;font-size:11px;color:#555}.dashboard__chart-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}.dashboard__bar-chart{display:flex;align-items:flex-end;gap:12px;height:140px;padding-top:10px}.dashboard__bar{flex:1;background:#e6f0ff;border-radius:4px 4px 0 0;position:relative;transition:height .3s;display:flex;align-items:flex-end;justify-content:center}.dashboard__bar span{position:absolute;bottom:-20px;font-size:10px;color:#888;font-weight:600}.dashboard__bar--current{background:#ffc600}.dashboard__ai-chat{flex:1;display:flex;flex-direction:column;background:linear-gradient(180deg,#fafbfc,#fff);border:1px solid #e8e8e8;border-radius:14px;overflow:hidden;min-height:0;box-shadow:0 2px 12px #0000000a}.dashboard__ai-messages{flex:1;overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:16px}.dashboard__ai-msg{display:flex;align-items:flex-start;gap:12px;max-width:75%;animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dashboard__ai-msg--assistant{align-self:flex-start}.dashboard__ai-msg--user{align-self:flex-end;flex-direction:row-reverse}.dashboard__ai-avatar{font-size:14px;flex-shrink:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%}.dashboard__ai-avatar--bot{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:13px}.dashboard__ai-avatar--user{background:#1a1a2e;color:#fff;font-size:12px;font-weight:700}.dashboard__ai-bubble{padding:12px 16px;border-radius:16px;font-size:13px;line-height:1.6;white-space:pre-line}.dashboard__ai-msg--assistant .dashboard__ai-bubble{background:#fff;color:#333;border:1px solid #eee;border-top-left-radius:4px;box-shadow:0 1px 4px #0000000a}.dashboard__ai-msg--user .dashboard__ai-bubble{background:linear-gradient(135deg,#1a1a2e,#2d2d4a);color:#fff;border-top-right-radius:4px}.dashboard__ai-input-area{display:flex;gap:10px;padding:16px 24px;border-top:1px solid #eee;background:#fff;flex-shrink:0}.dashboard__ai-input{flex:1;padding:12px 16px;border:1.5px solid #e0e0e0;border-radius:12px;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;background:#fafbfc}.dashboard__ai-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.dashboard__ai-send{width:42px;height:42px;border:none;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center}.dashboard__ai-send:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea4d}.dashboard__ai-send-icon{display:block;line-height:1}.dashboard__ai-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;position:relative}.dashboard__ai-welcome-glow{position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(102,126,234,.08) 0%,transparent 70%);pointer-events:none}.dashboard__ai-welcome-icon{font-size:42px;margin-bottom:14px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.dashboard__ai-welcome-title{font-size:24px;font-weight:700;color:#1a1a2e;margin:0 0 8px}.dashboard__ai-welcome-subtitle{font-size:14px;color:#777;margin:0 0 24px;text-align:center;max-width:440px;line-height:1.5}.dashboard__ai-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:28px;max-width:520px}.dashboard__ai-suggestion{padding:8px 14px;border:1px solid #e0e0e0;border-radius:20px;background:#fff;font-size:12px;color:#555;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000a}.dashboard__ai-suggestion:hover{border-color:#667eea;color:#667eea;background:#f8f7ff;box-shadow:0 2px 8px #667eea1f}.dashboard__ai-input-area--center{border-top:none;padding:0;width:100%;max-width:520px;background:transparent}.page-header{display:flex;align-items:center;justify-content:space-between;background:#f4f6f8;padding:8px 16px 8px 5px;border-radius:6px;margin-bottom:12px}.page-header__title{font-size:20px;font-weight:700;color:#1a1a2e;margin:0}.page-header__subtitle{font-size:12px;color:#666;margin:0}.page-header__btn{padding:7px 14px;border:none;border-radius:6px;background:#ffc600;color:#1a1a2e;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease}.page-header__btn:hover{background:#e6b300;box-shadow:0 4px 12px #ffc6004d}.filter-bar{display:flex;flex-wrap:wrap;gap:12px;background:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 1px 6px #0000000d;margin-bottom:12px;align-items:flex-end}.filter-bar__group{display:flex;flex-direction:column;gap:4px;min-width:140px}.filter-bar__label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.3px}.filter-bar__input{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:12px;color:#333;background:#fafafa;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.filter-bar__input:focus{border-color:#ffc600;box-shadow:0 0 0 3px #ffc60026}.filter-bar__actions{display:flex;align-items:flex-end;gap:8px;margin-left:auto}.filter-bar__apply-btn{padding:6px 12px;border:none;border-radius:4px;background:#ffc600;color:#1a1a2e;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease}.filter-bar__apply-btn:hover{background:#e6b300;box-shadow:0 2px 8px #ffc6004d}.filter-bar__clear-btn{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#555;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.filter-bar__clear-btn:hover{background:#f5f5f5;border-color:#bbb}.data-table__wrapper{background:#fff;border-radius:8px;box-shadow:0 1px 6px #0000000d;overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead{background:#f8f9fa;border-bottom:2px solid #eee}.data-table th{padding:8px 12px;text-align:left;font-size:11px;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.3px;position:relative;word-wrap:break-word;white-space:normal}.data-table td{padding:8px 12px;border-bottom:1px solid #f0f0f0;color:#333;word-wrap:break-word;white-space:normal}.data-table__resize-handle{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;background:transparent;transition:background .2s}.data-table__resize-handle:hover,.data-table__resize-handle:active{background:#ffc600}.data-table tbody tr:hover{background:#fffbe6}.data-table tbody tr:last-child td{border-bottom:none}.data-table__footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding:8px 12px;background:#fff;border-radius:6px;box-shadow:0 1px 4px #0000000a}.data-table__count{font-size:12px;color:#666;font-weight:500}.data-table__pagination{display:flex;align-items:center;gap:16px}.data-table__rows-per-page{display:flex;align-items:center;gap:6px;font-size:12px;color:#555}.data-table__rows-per-page select{padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:12px;background:#fafafa;cursor:pointer}.data-table__page-info{font-size:12px;color:#555}.data-table__page-buttons{display:flex;gap:4px}.data-table__page-buttons button{width:28px;height:28px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease}.data-table__page-buttons button:hover:not(:disabled){background:#f5f5f5;border-color:#bbb}.data-table__page-buttons button:disabled{opacity:.4;cursor:not-allowed}.design-page__number{font-family:SF Mono,Fira Code,monospace;font-weight:600;color:#1a1a2e}.design-page__action-group{display:flex;gap:6px}.design-page__action-btn{padding:3px 10px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:11px;font-weight:600;color:#1a1a2e;cursor:pointer;transition:background .2s,border-color .2s}.design-page__action-btn:hover{background:#ffc600;border-color:#ffc600}.design-page__action-btn--pac{background:#f0f4ff;border-color:#2563eb;color:#2563eb}.design-page__action-btn--pac:hover{background:#2563eb;border-color:#2563eb;color:#fff}.design-page__state{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.design-page__state--active{background:#e6f9ee;color:#1a8a4a}.design-page__state--draft{background:#fff4e6;color:#c67a00}.design-page__state--inactive{background:#f0f0f0;color:#666}.design-page__state--under-review{background:#e6f0ff;color:#2563eb}.design-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1000}.design-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:620px;max-height:80vh;background:#fff;border-radius:10px;box-shadow:0 8px 32px #0000002e;z-index:1001;display:flex;flex-direction:column;overflow:hidden}.design-modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #eee}.design-modal__title{font-size:16px;font-weight:700;color:#1a1a2e;margin:0}.design-modal__close{background:none;border:none;font-size:22px;color:#666;cursor:pointer;line-height:1}.design-modal__close:hover{color:#333}.design-modal__body{padding:16px 20px;overflow-y:auto}.design-modal__search{margin-bottom:16px}.design-modal__label{display:block;font-size:12px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.design-modal__search-row{display:flex;gap:8px}.design-modal__input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:13px;outline:none;transition:border-color .2s}.design-modal__input:focus{border-color:#ffc600;box-shadow:0 0 0 3px #ffc60026}.design-modal__search-btn{padding:8px 16px;border:none;border-radius:6px;background:#ffc600;color:#1a1a2e;font-size:12px;font-weight:600;cursor:pointer}.design-modal__search-btn:hover{background:#e6b300}.design-modal__error{margin:8px 0 0;font-size:12px;color:#dc2626}.design-modal__result{border-top:1px solid #eee;padding-top:14px}.design-modal__result-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.design-modal__result-field{display:flex;flex-direction:column;gap:2px}.design-modal__result-label{font-size:11px;font-weight:600;color:#888;text-transform:uppercase}.design-modal__result-value{font-size:13px;color:#333;font-weight:500}.design-modal__tabs{display:flex;gap:0;border-bottom:2px solid #eee;margin-bottom:12px}.design-modal__tab{padding:8px 16px;border:none;background:none;font-size:13px;font-weight:600;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.design-modal__tab:hover{color:#555}.design-modal__tab--active{color:#1a1a2e;border-bottom-color:#ffc600}.design-modal__template{display:flex;flex-direction:column;gap:10px}.design-modal__template-item{padding:10px 14px;border:1px solid #eee;border-radius:6px;cursor:pointer;transition:border-color .2s,background .2s}.design-modal__template-item:hover{border-color:#ffc600;background:#fffbe6}.design-modal__template-item strong{font-size:13px;color:#1a1a2e}.design-modal__template-item p{margin:4px 0 0;font-size:12px;color:#666}.design-modal__ai{display:flex;flex-direction:column;gap:10px}.design-modal__ai-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:13px;resize:vertical;outline:none;font-family:inherit;transition:border-color .2s}.design-modal__ai-input:focus{border-color:#ffc600;box-shadow:0 0 0 3px #ffc60026}.design-modal__ai-btn{align-self:flex-end;padding:8px 16px;border:none;border-radius:6px;background:#ffc600;color:#1a1a2e;font-size:12px;font-weight:600;cursor:pointer}.design-modal__ai-btn:hover:not(:disabled){background:#e6b300}.design-modal__ai-btn:disabled{opacity:.5;cursor:not-allowed}.design-page__skeleton{margin:16px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.design-page__skeleton-header{display:grid;grid-template-columns:1fr 2fr 1.2fr .8fr 1.5fr;gap:12px;padding:14px 16px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.design-page__skeleton-row{display:grid;grid-template-columns:1fr 2fr 1.2fr .8fr 1.5fr;gap:12px;padding:14px 16px;border-bottom:1px solid #f3f4f6}.design-page__skeleton-row:last-child{border-bottom:none}.design-page__skeleton-cell{height:14px;border-radius:4px;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6,#e5e7eb 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.design-page__skeleton-cell--header{height:12px;background:linear-gradient(90deg,#d1d5db 25%,#e5e7eb,#d1d5db 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.design-page__loading{text-align:center;padding:32px 16px;color:#666;font-size:13px}.design-page__error{padding:12px 16px;margin:8px 16px;background:#fef2f2;color:#dc2626;border-radius:6px;font-size:13px}.design-page__pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;font-size:13px;color:#444}.design-page__pagination button{padding:6px 14px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s}.design-page__pagination button:hover:not(:disabled){background:#ffc600;border-color:#ffc600}.design-page__pagination button:disabled{opacity:.4;cursor:not-allowed}.design-modal--pac{width:700px;max-height:85vh}.design-modal__json{background:#1e1e2e;color:#a6e3a1;padding:16px;border-radius:8px;font-size:12px;font-family:SF Mono,Fira Code,monospace;overflow:auto;max-height:60vh;white-space:pre-wrap;word-break:break-word;margin:0}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.design-detail__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 16px;color:#666;font-size:14px}.design-detail__loading-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#ffc600;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.design-detail__content{display:flex;flex-direction:column;gap:8px;height:calc(100vh - 120px)}.design-detail__info-section{background:#fff;border:1px solid #eee;border-radius:6px;flex-shrink:0}.design-detail__info-header{display:flex;align-items:center;justify-content:space-between;padding:7px 12px}.design-detail__info-left{display:flex;align-items:center;gap:8px}.design-detail__back-btn{background:none;border:1px solid #ddd;border-radius:4px;padding:3px 8px;font-size:13px;cursor:pointer;color:#555;line-height:1}.design-detail__back-btn:hover{background:#f4f6f8;border-color:#bbb}.design-detail__toggle{background:none;border:none;cursor:pointer;padding:2px 4px;font-size:10px;color:#888;transition:transform .2s}.design-detail__toggle-icon{display:inline-block;transition:transform .2s}.design-detail__toggle-icon--open{transform:rotate(90deg)}.design-detail__info-title{font-size:13px;color:#1a1a2e}.design-detail__info-title b{font-family:SF Mono,Fira Code,monospace}.design-detail__info-body{display:flex;align-items:center;gap:10px;padding:0 12px 8px 44px}.design-detail__info-chip{font-size:11px;color:#555;padding:3px 10px;background:#f4f6f8;border-radius:12px;display:flex;align-items:center;gap:4px}.design-detail__chip-label{font-size:10px;font-weight:600;color:#999;text-transform:uppercase}.design-detail__info-chip--method{background:#fffbe6;border:1px solid #FFC600;font-weight:600;color:#1a1a2e}.design-detail__editor-layout{display:grid;grid-template-columns:1fr 280px;gap:8px;flex:1;min-height:0}.design-detail__connectors-panel{background:#fff;border:1px solid #eee;border-radius:8px;display:flex;flex-direction:column;overflow:hidden;min-height:0;transition:width .2s ease}.design-detail__connectors-panel--collapsed{width:40px;min-width:40px}.design-detail__connectors-toggle{background:none;border:none;cursor:pointer;padding:2px 4px;font-size:10px;color:#888;transition:transform .2s}.design-detail__connectors-toggle-icon{display:inline-block;transition:transform .2s}.design-detail__connectors-toggle-icon--open{transform:rotate(0)}.design-detail__connectors-toggle-icon:not(.design-detail__connectors-toggle-icon--open){transform:rotate(180deg)}.design-detail__connectors-header{display:flex;align-items:center;gap:6px;padding:10px 12px;border-bottom:1px solid #eee;background:#f8f9fa;flex-shrink:0}.design-detail__connectors-title{margin:0;font-size:12px;font-weight:700;color:#1a1a2e}.design-detail__connectors-search{padding:8px 10px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.design-detail__connectors-input{width:100%;padding:5px 8px;border:1px solid #ddd;border-radius:4px;font-size:11px;outline:none}.design-detail__connectors-input:focus{border-color:#ffc600}.design-detail__connectors-list{flex:1;overflow-y:auto;padding:6px 0}.design-detail__connectors-loading,.design-detail__connectors-empty{padding:16px 12px;text-align:center;font-size:11px;color:#999}.design-detail__connectors-type-section{margin-bottom:8px}.design-detail__connectors-type-header{padding:6px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid #f0f0f0}.design-detail__connectors-type-header--trigger{color:#92400e;background:#fffbeb}.design-detail__connectors-type-header--action{color:#1e40af;background:#eff6ff}.design-detail__connectors-group{margin-bottom:4px}.design-detail__connectors-group-name{padding:4px 12px;font-size:10px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.3px}.design-detail__connectors-item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:default;transition:background .15s;position:relative}.design-detail__connectors-item:hover{background:#f4f6f8}.design-detail__connectors-item-add{display:none;width:20px;height:20px;border-radius:50%;border:1px solid #d1d5db;background:#fff;color:#374151;font-size:14px;font-weight:600;line-height:1;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.design-detail__connectors-item:hover .design-detail__connectors-item-add{display:flex}.design-detail__connectors-item-add:hover{background:#2563eb;border-color:#2563eb;color:#fff}.design-detail__connectors-item--disabled{opacity:.4;cursor:not-allowed}.design-detail__connectors-item--disabled:hover{background:transparent}.design-detail__connectors-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.design-detail__connectors-type-dot--trigger{background:#fbbf24;border:2px solid #d97706}.design-detail__connectors-type-dot--action{background:#60a5fa;border:2px solid #2563eb}.design-detail__connectors-item-info{flex:1;min-width:0;display:flex;flex-direction:column}.design-detail__connectors-item-name{font-size:11px;font-weight:600;color:#1a1a2e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.design-detail__connectors-item-desc{font-size:9px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.design-detail__connectors-item-badge{font-size:8px;font-weight:700;padding:1px 4px;border-radius:3px;text-transform:uppercase;flex-shrink:0}.design-detail__connectors-item-badge--trigger{background:#fef3c7;color:#92400e}.design-detail__connectors-item-badge--action{background:#dbeafe;color:#1e40af}.design-detail__connectors-item-tag{font-size:9px;font-weight:600;padding:2px 6px;border-radius:3px;text-transform:capitalize;flex-shrink:0;white-space:nowrap}.design-detail__connectors-item-tag--trigger{background:#fef3c7;color:#92400e}.design-detail__connectors-item-tag--action{background:#dbeafe;color:#1e40af}.design-detail__editor-panel{background:#fff;border:1px solid #eee;border-radius:8px;display:flex;flex-direction:column;overflow:hidden;min-height:0}.design-detail__editor-toolbar{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #eee;padding:0 10px;flex-shrink:0}.design-detail__editor-tabs{display:flex}.design-detail__editor-tab{padding:8px 14px;border:none;background:none;font-size:12px;font-weight:600;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.design-detail__editor-tab:hover{color:#555}.design-detail__editor-tab--active{color:#1a1a2e;border-bottom-color:#ffc600}.design-detail__direction-btn{padding:4px 10px;border:1px solid #ddd;border-radius:4px;background:#f8f9fa;font-size:11px;font-weight:600;color:#555;cursor:pointer;transition:background .2s,border-color .2s}.design-detail__direction-btn:hover{background:#eee;border-color:#bbb}.design-detail__editor-content{flex:1;position:relative;min-height:0}.design-detail__flow-container{width:100%;height:100%}.design-detail__json-editor{width:100%;height:100%;padding:10px;border:none;font-family:SF Mono,Fira Code,monospace;font-size:11px;line-height:1.5;color:#333;resize:none;outline:none;background:#fafafa}.design-detail__ai-panel{background:#fff;border:1px solid #eee;border-radius:8px;display:flex;flex-direction:column;overflow:hidden;min-height:0}.design-detail__ai-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid #eee;background:#f8f9fa;flex-shrink:0}.design-detail__ai-title{margin:0;font-size:12px;font-weight:700;color:#1a1a2e}.design-detail__ai-messages{flex:1;overflow-y:auto;padding:8px 10px;display:flex;flex-direction:column;gap:6px;min-height:0}.design-detail__ai-msg{padding:6px 9px;border-radius:6px;font-size:11px;line-height:1.4;max-width:92%}.design-detail__ai-msg--assistant{background:#f4f6f8;color:#333;align-self:flex-start}.design-detail__ai-msg--user{background:#ffc600;color:#1a1a2e;align-self:flex-end}.design-detail__ai-input-row{display:flex;gap:5px;padding:8px 10px;border-top:1px solid #eee;flex-shrink:0}.design-detail__ai-input{flex:1;padding:6px 9px;border:1px solid #ddd;border-radius:5px;font-size:11px;outline:none}.design-detail__ai-input:focus{border-color:#ffc600}.design-detail__ai-send{padding:6px 10px;border:none;border-radius:5px;background:#ffc600;color:#1a1a2e;font-size:11px;font-weight:600;cursor:pointer}.design-detail__ai-send:hover{background:#e6b300}.design-detail__props-close{background:none;border:none;font-size:18px;color:#999;cursor:pointer;padding:0 4px;line-height:1}.design-detail__props-close:hover{color:#333}.design-detail__props-body{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.design-detail__props-section{display:flex;flex-direction:column;gap:3px}.design-detail__props-label{font-size:10px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.3px}.design-detail__props-input{padding:5px 8px;border:1px solid #ddd;border-radius:4px;font-size:11px;outline:none;color:#333}.design-detail__props-input:focus{border-color:#ffc600}.design-detail__props-input[readonly]{background:#f8f9fa;color:#666}.design-detail__props-type-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:capitalize;width:fit-content}.design-detail__props-type-badge--trigger{background:#fef3c7;color:#92400e}.design-detail__props-type-badge--action{background:#dbeafe;color:#1e40af}.design-detail__props-divider{height:1px;background:#eee;margin:4px 0}.design-detail__props-section-title{font-size:11px;font-weight:700;color:#1a1a2e;margin-bottom:2px}.design-detail__props-group{display:flex;flex-direction:column;gap:6px;padding:6px 8px;background:#f9fafb;border-radius:6px;border:1px solid #f0f0f0}.design-detail__actions{display:flex;gap:6px;align-items:center}.design-detail__btn{padding:5px 12px;border:none;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;transition:background .2s}.design-detail__btn--primary{background:#ffc600;color:#1a1a2e}.design-detail__btn--primary:hover{background:#e6b300}.design-detail__btn--secondary{background:#1a1a2e;color:#fff}.design-detail__btn--secondary:hover{background:#2d2d4a}.design-detail__btn--outline{background:#fff;color:#1a1a2e;border:1px solid #ddd}.design-detail__btn--outline:hover{background:#f4f6f8;border-color:#bbb}.design-detail__btn--accent{background:#2563eb;color:#fff}.design-detail__btn--accent:hover{background:#1d4ed8}.connector-node{padding:12px 16px;border-radius:10px;min-width:200px;box-shadow:0 2px 8px #00000014}.connector-node--trigger{background:#fffbeb;border:2px solid #f59e0b}.connector-node--action{background:#eff6ff;border:2px solid #3b82f6}.connector-node__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.connector-node__badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase}.connector-node__badge--trigger{background:#fef3c7;color:#92400e}.connector-node__badge--action{background:#dbeafe;color:#1e40af}.connector-node__step{font-size:10px;color:#9ca3af;font-weight:500}.connector-node__name{font-size:13px;font-weight:600;color:#1f2937;margin-bottom:2px}.connector-node__connector{font-size:10px;color:#6b7280;margin-bottom:3px;font-family:SF Mono,Fira Code,monospace}.connector-node__desc{font-size:10px;color:#9ca3af;margin-bottom:6px}.connector-node__props{border-top:1px solid #e5e7eb;padding-top:5px}.connector-node__prop{font-size:9px;color:#6b7280}.connector-node__prop b{color:#374151}.design-detail__json-background{padding:8px 10px;overflow-y:auto;max-height:200px;border-bottom:1px solid #eee}.design-detail__json-preview{font-family:SF Mono,Fira Code,monospace;font-size:10px;line-height:1.4;color:#374151;background:#f9fafb;padding:8px;border-radius:6px;border:1px solid #e5e7eb;margin:0 0 8px;white-space:pre-wrap;overflow-y:auto;max-height:120px}.design-detail__connection-map{display:flex;flex-direction:column;gap:4px}.design-detail__map-title{font-size:10px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.design-detail__map-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#374151}.design-detail__map-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.design-detail__map-dot--trigger{background:#fbbf24;border:2px solid #d97706}.design-detail__map-dot--action{background:#60a5fa;border:2px solid #2563eb}.design-detail__map-arrow{font-size:10px;color:#9ca3af;margin-left:auto}.add-node{width:40px;height:40px;border-radius:50%;background:#f3f4f6;border:2px dashed #d1d5db;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.add-node:hover{background:#ffc600;border-color:#eab308;transform:scale(1.15)}.add-node__icon{font-size:22px;font-weight:600;color:#9ca3af;line-height:1}.add-node:hover .add-node__icon{color:#1f2937}.add-modal__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.add-modal{background:#fff;border-radius:12px;width:560px;max-height:580px;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000026}.add-modal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid #e5e7eb}.add-modal__title{margin:0;font-size:15px;font-weight:600;color:#1f2937}.add-modal__header-actions{display:flex;align-items:center;gap:10px}.add-modal__view-toggle{display:flex;border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}.add-modal__view-btn{background:#fff;border:none;padding:4px 8px;font-size:14px;cursor:pointer;color:#9ca3af;line-height:1;transition:all .12s}.add-modal__view-btn:not(:last-child){border-right:1px solid #e5e7eb}.add-modal__view-btn--active{background:#f3f4f6;color:#1f2937}.add-modal__view-btn:hover:not(.add-modal__view-btn--active){background:#f9fafb}.add-modal__close{background:none;border:none;font-size:20px;cursor:pointer;color:#6b7280;padding:0 4px}.add-modal__close:hover{color:#1f2937}.add-modal__search{padding:12px 20px}.add-modal__search-input{width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;outline:none;box-sizing:border-box}.add-modal__search-input:focus{border-color:#ffc600;box-shadow:0 0 0 2px #ffc60026}.add-modal__list{overflow-y:auto;padding:0 20px 8px;flex:1}.add-modal__empty{padding:24px 0;text-align:center;color:#9ca3af;font-size:13px}.add-modal__item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .12s;border:2px solid transparent}.add-modal__item:hover{background:#f9fafb}.add-modal__item--selected{background:#fffbeb;border-color:#ffc600}.add-modal__item--disabled{opacity:.4;cursor:not-allowed}.add-modal__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.add-modal__dot--trigger{background:#f59e0b}.add-modal__dot--action{background:#3b82f6}.add-modal__item-info{flex:1;min-width:0}.add-modal__item-name{display:block;font-size:13px;font-weight:500;color:#1f2937}.add-modal__item-desc{display:block;font-size:11px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-modal__item-tag{font-size:9px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;flex-shrink:0}.add-modal__item-tag--trigger{background:#fef3c7;color:#92400e}.add-modal__item-tag--action{background:#dbeafe;color:#1e40af}.add-modal__gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.add-modal__card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;text-align:center;transition:all .12s;background:#fff}.add-modal__card:hover{border-color:#d1d5db;background:#f9fafb}.add-modal__card--selected{border-color:#ffc600;background:#fffbeb}.add-modal__card--disabled{opacity:.4;cursor:not-allowed}.add-modal__card-dot{width:10px;height:10px;border-radius:50%}.add-modal__card-dot--trigger{background:#f59e0b}.add-modal__card-dot--action{background:#3b82f6}.add-modal__card-name{font-size:12px;font-weight:600;color:#1f2937;line-height:1.2}.add-modal__card-connector{font-size:10px;color:#6b7280;font-family:SF Mono,Fira Code,monospace}.add-modal__card-desc{font-size:10px;color:#9ca3af;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.add-modal__card-tag{font-size:8px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase}.add-modal__card-tag--trigger{background:#fef3c7;color:#92400e}.add-modal__card-tag--action{background:#dbeafe;color:#1e40af}.add-modal__footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid #e5e7eb}.add-modal__cancel-btn{padding:7px 16px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer}.add-modal__cancel-btn:hover{background:#f9fafb;color:#1f2937}.add-modal__add-btn{padding:7px 20px;border:none;border-radius:6px;background:#ffc600;color:#1a1a2e;font-size:13px;font-weight:600;cursor:pointer;transition:all .12s}.add-modal__add-btn:hover:not(:disabled){background:#eab308}.add-modal__add-btn:disabled{opacity:.4;cursor:not-allowed}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:6px;font-size:13px;font-weight:500;box-shadow:0 4px 12px #00000026;animation:toast-drop .3s ease}.toast--success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.toast--error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast__icon{font-size:15px;font-weight:700}.toast__message{flex:1}.toast__close{background:none;border:none;font-size:16px;cursor:pointer;color:inherit;opacity:.6;padding:0 4px}.toast__close:hover{opacity:1}@keyframes toast-drop{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.implement-page__number{font-family:SF Mono,Fira Code,monospace;font-weight:600;color:#1a1a2e}.implement-page__status{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.implement-page__status--implemented{background:#e6f9ee;color:#1a8a4a}.implement-page__status--in-progress{background:#e6f0ff;color:#2563eb}.implement-page__status--not-started{background:#fff4e6;color:#c67a00}.implement-page__status--blocked{background:#fee2e2;color:#dc2626}.execution-page__filters{display:flex;flex-wrap:wrap;gap:16px;background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 2px 12px #0000000f;margin-bottom:24px;align-items:flex-end}.execution-page__filter-group{display:flex;flex-direction:column;gap:6px;min-width:160px}.execution-page__filter-label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.3px}.execution-page__filter-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:13px;color:#333;background:#fafafa;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.execution-page__filter-input:focus{border-color:#ffc600;box-shadow:0 0 0 3px #ffc60026}.execution-page__filter-actions{flex-direction:row;gap:8px;align-items:flex-end;margin-left:auto}.execution-page__apply-btn{padding:8px 16px;border:none;border-radius:6px;background:#ffc600;color:#1a1a2e;font-size:13px;font-weight:600;cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease}.execution-page__apply-btn:hover{background-color:#e6b200;box-shadow:0 2px 6px #ffc6004d}.execution-page__clear-btn{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#555;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.execution-page__clear-btn:hover{background-color:#f0f0f0;border-color:#bbb}.execution-page__table-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000f;overflow:hidden}.execution-page__table{width:100%;border-collapse:collapse;font-size:13px}.execution-page__table thead{background:#f8f9fa}.execution-page__table th{padding:14px 16px;text-align:left;font-weight:600;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid #eee}.execution-page__table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#333}.execution-page__table tbody tr:hover{background-color:#fafafa}.execution-page__table tbody tr:last-child td{border-bottom:none}.execution-page__id{font-weight:600;color:#1a1a2e}.execution-page__status{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.execution-page__status--completed{background-color:#e8f5e9;color:#2e7d32}.execution-page__status--in-progress{background-color:#e3f2fd;color:#1565c0}.execution-page__status--failed{background-color:#fce4ec;color:#c62828}.execution-page__status--pending{background-color:#fff3e0;color:#e65100}.execution-page__status--observation{background-color:#fff3e0;color:#db9e02}.execution-page__empty{text-align:center;padding:40px 16px!important;color:#999;font-style:italic}.execution-page__footer{margin-top:16px;font-size:13px;color:#888;text-align:right}.execution-page__view-btn{padding:5px 12px;border:1px solid #FFC600;border-radius:4px;background:transparent;color:#b38a00;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s ease,color .2s ease}.execution-page__view-btn:hover{background-color:#ffc600;color:#1a1a2e}.execution-drawer__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:999}.execution-drawer{position:fixed;top:0;right:0;width:460px;height:100vh;background:#fff;box-shadow:-4px 0 20px #0000001f;z-index:1000;display:flex;flex-direction:column;animation:slideInRight .25s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.execution-drawer__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;flex-shrink:0}.execution-drawer__title{font-size:14px;font-weight:700;color:#1a1a2e;margin:0}.execution-drawer__header-actions{display:flex;gap:6px}.execution-drawer__expand-btn,.execution-drawer__close-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#555;cursor:pointer;transition:background .15s ease}.execution-drawer__expand-btn:hover,.execution-drawer__close-btn:hover{background:#f0f0f0;color:#333}.execution-drawer__body{flex:1;overflow-y:auto;padding:16px 20px}.execution-drawer__info{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.execution-drawer__info-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.execution-drawer__label{font-weight:600;color:#555}.execution-drawer__section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#555;margin:0 0 12px}.execution-drawer__timeline{display:flex;flex-direction:column}.execution-drawer__timeline-item{display:flex;gap:12px}.execution-drawer__timeline-indicator{display:flex;flex-direction:column;align-items:center;width:16px;flex-shrink:0}.execution-drawer__dot{width:10px;height:10px;border-radius:50%;border:2px solid #ccc;background:#fff;flex-shrink:0;margin-top:12px}.execution-drawer__dot--passed{border-color:#2e7d32;background:#e8f5e9}.execution-drawer__dot--failed{border-color:#c62828;background:#fce4ec}.execution-drawer__dot--in-progress{border-color:#1565c0;background:#e3f2fd}.execution-drawer__dot--pending{border-color:#bbb;background:#f5f5f5}.execution-drawer__dot--skipped{border-color:#e65100;background:#fff3e0}.execution-drawer__dot--observation{border-color:#db9e02;background:#fff3e0}.execution-drawer__line{width:2px;flex:1;background:#ddd;min-height:8px}.execution-drawer__step-card{flex:1;background:#f8f9fa;border:1px solid #eee;border-radius:6px;padding:8px 12px;margin-bottom:8px}.execution-drawer__step-header{display:flex;align-items:center;gap:8px;margin-bottom:3px}.execution-drawer__step-no{font-size:10px;font-weight:700;color:#1a1a2e;text-transform:uppercase}.execution-drawer__step-meta{display:flex;align-items:center;gap:6px;margin-left:auto}.execution-drawer__step-status{display:inline-flex;align-items:center;gap:2px;padding:1px 5px;border-radius:6px;font-size:9px;font-weight:600;text-transform:uppercase}.execution-drawer__step-status--passed,.execution-drawer__step-status--completed{background:#e8f5e9;color:#2e7d32}.execution-drawer__step-status--failed{background:#fce4ec;color:#c62828}.execution-drawer__step-status--in-progress{background:#e3f2fd;color:#1565c0}.execution-drawer__step-status--pending{background:#f5f5f5;color:#888}.execution-drawer__step-status--skipped{background:#fff3e0;color:#e65100}.execution-drawer__step-status--not-started{background:#f5f5f5;color:#888}.execution-drawer__step-status--observation{background:#fff3e0;color:#db9e02}.execution-drawer__step-time{font-size:9px;color:#999}.execution-drawer__step-name{font-size:12px;font-weight:600;color:#333;margin:2px 0}.execution-drawer__step-details{font-size:11px;color:#666;margin:0;line-height:1.3}.execution-drawer__step-connector{font-size:10px;font-weight:600;color:#1565c0;background:#e3f2fd;padding:2px 6px;border-radius:4px}.execution-drawer__loading{display:flex;flex-direction:column;height:100%}.execution-drawer__loading .execution-drawer__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}.execution-drawer__loading .execution-drawer__body{padding:20px}.execution-page__skeleton{display:flex;flex-direction:column;gap:24px}.execution-page__skeleton-filters{display:flex;gap:16px;background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 2px 12px #0000000f}.execution-page__skeleton-table{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000f;overflow:hidden;padding:0}.execution-page__skeleton-header{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;padding:16px 20px;background:#f8f9fa;border-bottom:2px solid #eee}.execution-page__skeleton-row{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;padding:14px 20px;border-bottom:1px solid #f0f0f0}.execution-page__skeleton-bar{border-radius:4px;background:#e8e8e8}.execution-view__skeleton{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 12px #0000000f}.execution-view__skeleton-bar{border-radius:4px;background:#e8e8e8}.execution-view__step-connector-badge{font-size:10px;font-weight:600;color:#1565c0;background:#e3f2fd;padding:2px 6px;border-radius:4px}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}.execution-view__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.execution-view__back-btn{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#555;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.execution-view__back-btn:hover{background-color:#f0f0f0;border-color:#bbb}.execution-view__content{display:flex;flex-direction:column;gap:14px}.execution-view__section{background:#fff;border-radius:8px;padding:20px 24px;box-shadow:0 1px 6px #0000000d}.execution-view__section-title{font-size:13px;font-weight:600;color:#1a1a2e;margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid #eee}.execution-view__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px 24px}.execution-view__field{display:flex;flex-direction:column;gap:4px;min-width:0}.execution-view__field--wide{grid-column:span 2}.execution-view__label{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.3px}.execution-view__value{font-size:13px;color:#333;font-weight:500;word-break:break-word}.execution-view__description{font-size:14px;color:#444;line-height:1.6;margin:0}.execution-view__timeline{display:flex;flex-direction:column}.execution-view__timeline-item{display:flex;gap:16px}.execution-view__timeline-indicator{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0}.execution-view__timeline-dot{width:14px;height:14px;border-radius:50%;border:2px solid #ccc;background:#fff;flex-shrink:0;margin-top:18px}.execution-view__timeline-dot--passed{border-color:#2e7d32;background:#e8f5e9}.execution-view__timeline-dot--failed{border-color:#c62828;background:#fce4ec}.execution-view__timeline-dot--in-progress{border-color:#1565c0;background:#e3f2fd}.execution-view__timeline-dot--pending{border-color:#bbb;background:#f5f5f5}.execution-view__timeline-dot--skipped{border-color:#e65100;background:#fff3e0}.execution-view__timeline-dot--observation{border-color:#db9e02;background:#fff3e0}.execution-view__timeline-line{width:2px;flex:1;background:#ddd;min-height:12px}.execution-view__step-card{flex:1;background:#f8f9fa;border:1px solid #eee;border-radius:6px;padding:10px 14px;margin-bottom:8px;transition:box-shadow .2s ease,border-color .2s ease}.execution-view__step-card:hover{box-shadow:0 1px 6px #0000000f;border-color:#ddd}.execution-view__step-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.execution-view__step-card-header-left{display:flex;align-items:center;gap:8px}.execution-view__step-card-header-right{display:flex;align-items:center;gap:6px}.execution-view__step-no{font-size:11px;font-weight:700;color:#1a1a2e;text-transform:uppercase;letter-spacing:.3px}.execution-view__step-separator{color:#999;font-size:18px;line-height:1}.execution-view__step-name{font-size:13px;font-weight:600;color:#333;margin:0 0 2px}.execution-view__step-details{font-size:12px;color:#666;margin:0 0 8px;line-height:1.3}.execution-view__step-actions{display:flex;gap:8px;margin-top:6px;justify-content:flex-end}.execution-view__step-time{font-size:10px;color:#999}.execution-view__step-download{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;color:#555;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.execution-view__step-download:hover{background:#f0f0f0;border-color:#bbb;color:#333}.execution-view__step-log-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;color:#555;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.execution-view__step-log-btn:hover{background:#f0f0f0;border-color:#bbb;color:#333}.execution-view__log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1100}.execution-view__log-modal{background:#fff;border-radius:8px;width:600px;max-width:90vw;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 8px 30px #00000026;animation:fadeInScale .2s ease}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.execution-view__log-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid #eee}.execution-view__log-header h3{margin:0;font-size:13px;font-weight:700;color:#1a1a2e}.execution-view__log-header-actions{display:flex;align-items:center;gap:4px}.execution-view__log-download-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:transparent;color:#555;border-radius:4px;cursor:pointer}.execution-view__log-download-btn:hover{background:#f0f0f0;color:#333}.execution-view__log-close{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:transparent;color:#555;border-radius:4px;cursor:pointer}.execution-view__log-close:hover{background:#f0f0f0;color:#333}.execution-view__log-content{flex:1;overflow-y:auto;padding:16px 18px;margin:0;font-family:SF Mono,Menlo,Monaco,monospace;font-size:12px;line-height:1.6;color:#d4d4d4;background:#1e1e1e;border-radius:0 0 8px 8px;white-space:pre-wrap;word-break:break-word}.execution-view__step-status{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.execution-view__step-status--passed{background-color:#e8f5e9;color:#2e7d32}.execution-view__step-status--failed{background-color:#fce4ec;color:#c62828}.execution-view__step-status--in-progress{background-color:#e3f2fd;color:#1565c0}.execution-view__step-status--pending{background-color:#f5f5f5;color:#888}.execution-view__step-status--skipped{background-color:#fff3e0;color:#e65100}.execution-view__step-status--observation{background-color:#fff3e0;color:#db9e02}.execution-view__log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;animation:logOverlayFadeIn .25s ease-out}.execution-view__log-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:820px;max-width:92vw;max-height:85vh;background:#fff;border-radius:12px;box-shadow:0 12px 48px #0003;z-index:1001;display:flex;flex-direction:column;overflow:hidden;animation:logModalSlideIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes logOverlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes logModalSlideIn{0%{opacity:0;transform:translate(-50%,-45%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.execution-view__log-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #eee}.execution-view__log-modal-title-wrap{display:flex;align-items:center;gap:12px}.execution-view__log-modal-title{font-size:16px;font-weight:700;color:#1a1a2e;margin:0}.execution-view__log-modal-filename{font-size:12px;font-family:SF Mono,Fira Code,monospace;color:#666;background:#f4f4f5;padding:3px 8px;border-radius:4px}.execution-view__log-modal-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;line-height:1;padding:4px 8px;border-radius:4px}.execution-view__log-modal-close:hover{background:#f4f4f5;color:#333}.execution-view__log-modal-body{flex:1;overflow-y:auto;padding:16px 20px}.execution-view__log-loading{text-align:center;padding:32px;color:#666;font-size:13px}.execution-view__log-error{padding:12px 16px;background:#fef2f2;color:#dc2626;border-radius:6px;font-size:13px}.execution-view__log-content{background:#1e1e2e;color:#cdd6f4;padding:16px 18px;border-radius:8px;font-size:11.5px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;line-height:1.7;overflow-x:auto;white-space:pre-wrap;word-break:break-word;margin:0}.audit-trail__filters{display:flex;flex-wrap:wrap;gap:16px;background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 2px 12px #0000000f;margin-bottom:24px;align-items:flex-end}.audit-trail__filter-group{display:flex;flex-direction:column;gap:6px;min-width:160px}.audit-trail__filter-label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.3px}.audit-trail__filter-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:13px;color:#333;background:#fafafa;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.audit-trail__filter-input:focus{border-color:#ffc600;box-shadow:0 0 0 3px #ffc60026}.audit-trail__filter-actions{flex-direction:row;gap:8px;align-items:flex-end;margin-left:auto}.audit-trail__apply-btn{padding:8px 20px;background:#1a1a2e;color:#ffc600;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.audit-trail__apply-btn:hover{background:#2a2a4e}.audit-trail__clear-btn{padding:8px 20px;background:transparent;color:#666;border:1px solid #ddd;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:border-color .2s ease,color .2s ease}.audit-trail__clear-btn:hover{border-color:#999;color:#333}.audit-trail__table-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000f;overflow:hidden;margin-bottom:16px}.audit-trail__table{width:100%;border-collapse:collapse;font-size:13px}.audit-trail__table th{padding:12px 14px;text-align:left;font-weight:600;color:#555;font-size:11px;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid #eee;background:#f8f9fa}.audit-trail__table td{padding:10px 14px;border-bottom:1px solid #f0f0f0;color:#333}.audit-trail__table tbody tr:hover{background-color:#fafafa}.audit-trail__table tbody tr:last-child td{border-bottom:none}.audit-trail__id{font-weight:600;color:#1a1a2e}.audit-trail__action{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600;text-transform:uppercase}.audit-trail__action--executed{background:#e8f5e9;color:#2e7d32}.audit-trail__action--failed{background:#fce4ec;color:#c62828}.audit-trail__action--started{background:#e3f2fd;color:#1565c0}.audit-trail__action--skipped{background:#fff3e0;color:#e65100}.audit-trail__action--scheduled{background:#f3e5f5;color:#6a1b9a}.audit-trail__action--modified{background:#fff8e1;color:#f57f17}.audit-trail__severity{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600}.audit-trail__severity--info{background:#e3f2fd;color:#1565c0}.audit-trail__severity--warning{background:#fff3e0;color:#e65100}.audit-trail__severity--error{background:#fce4ec;color:#c62828}.audit-trail__severity--success{background:#e8f5e9;color:#2e7d32}.audit-trail__empty{text-align:center;padding:40px 20px!important;color:#999;font-style:italic}.audit-trail__footer{font-size:12px;color:#888;padding:8px 0}.approval__toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 2px 12px #0000000f;margin-bottom:24px}.approval__filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.approval__filter-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:13px;color:#333;background:#f9f9f9;min-width:140px}.approval__filter-input:focus{outline:none;border-color:#dd1d21;background:#fff}.approval__actions{display:flex;gap:8px}.approval__btn{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background-color .2s,opacity .2s}.approval__btn:disabled{opacity:.5;cursor:not-allowed}.approval__btn--approve{background:#10b981;color:#fff}.approval__btn--approve:hover:not(:disabled){background:#059669}.approval__btn--reject{background:#ef4444;color:#fff}.approval__btn--reject:hover:not(:disabled){background:#dc2626}.approval__btn--clear{background:#f3f4f6;color:#555;border:1px solid #ddd}.approval__btn--clear:hover{background:#e5e7eb}.approval__table-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000f;overflow-x:auto}.approval__table{width:100%;border-collapse:collapse;font-size:13px}.approval__table thead{background:#f8f9fa;border-bottom:2px solid #e8e8e8}.approval__table th{padding:12px 14px;text-align:left;font-weight:600;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.approval__table td{padding:12px 14px;border-bottom:1px solid #f0f0f0;color:#333;vertical-align:middle}.approval__table tbody tr:hover{background:#fefce8}.approval__row--selected{background:#fffbeb!important}.approval__id{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:#666}.approval__type{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.approval__type--exception{background:#fef3c7;color:#92400e}.approval__type--override{background:#fce7f3;color:#9d174d}.approval__type--access{background:#dbeafe;color:#1e40af}.approval__type--change{background:#e0e7ff;color:#3730a3}.approval__priority{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.approval__priority--high{background:#fee2e2;color:#991b1b}.approval__priority--medium{background:#fef3c7;color:#92400e}.approval__priority--low{background:#d1fae5;color:#065f46}.approval__decision{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.approval__decision--approved{background:#d1fae5;color:#065f46}.approval__decision--rejected{background:#fee2e2;color:#991b1b}.approval__row-actions{display:flex;gap:6px}.approval__row-btn{width:28px;height:28px;border:none;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background-color .2s,transform .1s}.approval__row-btn:hover{transform:scale(1.1)}.approval__row-btn--approve{background:#d1fae5;color:#065f46}.approval__row-btn--approve:hover{background:#10b981;color:#fff}.approval__row-btn--reject{background:#fee2e2;color:#991b1b}.approval__row-btn--reject:hover{background:#ef4444;color:#fff}.approval__frequency{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.approval__frequency--daily{background:#dbeafe;color:#1e40af}.approval__frequency--weekly{background:#e0e7ff;color:#3730a3}.approval__frequency--monthly{background:#fef3c7;color:#92400e}.approval__frequency--quarterly{background:#fce7f3;color:#9d174d}.approval__frequency--annual{background:#d1fae5;color:#065f46}.approval__detail-btn{padding:6px 12px;background:#dd1d21;color:#fff;border:none;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .2s}.approval__detail-btn:hover{background:#b91c1c}.approval__back-btn{background:none;border:none;color:#dd1d21;font-size:13px;font-weight:600;cursor:pointer;padding:0;margin-bottom:12px}.approval__back-btn:hover{text-decoration:underline}.approval__detail-header{margin-bottom:24px}.approval__detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.approval__detail-card{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 2px 12px #0000000f}.approval__detail-card--full{margin-bottom:24px}.approval__detail-card-title{font-size:14px;font-weight:700;color:#333;margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid #eee}.approval__detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f5f5f5}.approval__detail-row:last-child{border-bottom:none}.approval__detail-label{font-size:13px;color:#666;font-weight:500}.approval__detail-value{font-size:13px;color:#333;font-weight:600;text-align:right;max-width:60%}.approval__result--passed{color:#065f46}.approval__result--failed{color:#991b1b}.approval__step-status{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.approval__step-status--passed{background:#d1fae5;color:#065f46}.approval__step-status--failed{background:#fee2e2;color:#991b1b}.approval__step-status--pending{background:#fef3c7;color:#92400e}.approval__step-status--skipped{background:#f3f4f6;color:#6b7280}.approval__detail-actions{display:flex;gap:12px}.approval__document{display:flex;align-items:center;gap:16px;padding:16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.approval__document-icon{font-size:32px;line-height:1}.approval__document-info{display:flex;flex-direction:column;gap:4px;flex:1}.approval__document-name{font-size:14px;font-weight:600;color:#333}.approval__document-meta{font-size:12px;color:#888}.approval__document-download{padding:8px 16px;background:#dd1d21;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .2s}.approval__document-download:hover{background:#b91c1c}.approval__ai-section{border-left:4px solid #6366f1}.approval__ai-header{display:flex;justify-content:space-between;align-items:center}.approval__ai-risk{padding:4px 10px;border-radius:4px;font-size:12px;font-weight:700;text-transform:uppercase}.approval__ai-risk--low{background:#d1fae5;color:#065f46}.approval__ai-risk--medium{background:#fef3c7;color:#92400e}.approval__ai-risk--high{background:#fee2e2;color:#991b1b}.approval__ai-summary{font-size:14px;color:#333;line-height:1.6;margin:12px 0 20px;padding:12px 16px;background:#f5f3ff;border-radius:6px}.approval__ai-findings{margin-bottom:20px}.approval__ai-findings-title{font-size:13px;font-weight:700;color:#444;margin:0 0 10px}.approval__ai-findings-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.approval__ai-finding-item{font-size:13px;color:#555;background:#fff;border:1px solid #e5e7eb;border-radius:6px;position:relative;padding:8px 12px 8px 28px}.approval__ai-finding-item:before{content:"•";position:absolute;left:12px;color:#6366f1;font-weight:700}.approval__ai-recommendation{padding:12px 16px;background:#fffbeb;border:1px solid #fde68a;border-radius:6px}.approval__ai-recommendation-title{font-size:13px;font-weight:700;color:#92400e;margin:0 0 6px}.approval__ai-recommendation-text{font-size:13px;color:#78350f;margin:0;line-height:1.5}.approval__empty{text-align:center;padding:48px 24px!important;color:#999;font-style:italic}.approval__footer{margin-top:16px;padding:12px 20px;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000000a;font-size:13px;color:#666}.page{max-width:1400px}.page__header{margin-bottom:12px}.page__title{font-size:28px;font-weight:700;color:#1a1a2e;margin:0 0 8px}.page__subtitle{font-size:14px;color:#666;margin:0}.page__content{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000f;min-height:400px;display:flex;align-items:center;justify-content:center}.page__placeholder{text-align:center;color:#999}.page__placeholder-icon{font-size:48px;display:block;margin-bottom:16px}.page__placeholder p{font-size:14px}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;color:#1a1a2e;background-color:#f5f6fa;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}
