@import"https://fonts.googleapis.com/css2?family=Futura+PT:wght@400;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Minion+Pro:wght@400;700&display=swap";.sidebar{width:250px;flex-grow:0;flex-shrink:0;flex-basis:250px;display:flex;flex-direction:column;background-color:var(--color-white);border-right:1px solid var(--color-border);padding:12px 0;margin:12px;border-radius:var(--radius-lg);color:var(--color-text);font-size:.85rem;font-family:var(--font-body);box-shadow:0 2px 8px #0000000f}.sidebar-header{padding:0 20px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center}.sidebar-header h2{margin:0;padding:0;font-size:1.3rem;font-weight:600;color:var(--color-text)!important;line-height:1.2;font-family:var(--font-heading);white-space:nowrap}.sidebar-button{display:flex;align-items:center;padding:10px 20px;background:none;border:none;text-align:left;font-size:.85rem;font-weight:500;color:var(--color-text);cursor:pointer;width:100%;transition:background-color .2s,color .2s;border-radius:var(--radius-md)}.sidebar-button:hover{background-color:var(--color-hover);color:var(--color-accent)}.sidebar-button.active{background-color:var(--color-light);color:var(--color-accent);font-weight:600}.icon{margin-right:8px;font-size:.75rem;color:var(--color-accent)}.toggle-button{margin-top:10px}.recent-list{overflow:visible;max-height:0;opacity:0;transition:max-height .3s ease,opacity .3s ease;will-change:max-height,opacity}.recent-list.open{max-height:500px;opacity:1}.recent-list.closed{max-height:0;opacity:0}.recent-item{display:flex;align-items:center;padding:8px 12px 8px 20px;cursor:pointer;font-size:.8rem;color:var(--color-text);transition:background-color .3s;border-radius:var(--radius-pill);gap:8px}.recent-item:hover{background-color:var(--color-offwhite);color:var(--color-accent)}.recent-item.active{background-color:var(--color-light);font-weight:600;color:var(--color-accent)}.migration-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:gray;position:relative;cursor:pointer}.migration-status{flex-shrink:0;font-size:.7rem;padding:2px 6px;border-radius:var(--radius-pill);text-transform:capitalize;font-weight:500;margin-right:8px}.status-completed{background-color:#e8f5e9;color:#388e3c;border-radius:var(--radius-md)}.no-migrations{padding:10px 20px 10px 40px;color:var(--color-muted);font-style:italic;font-size:.8rem}.menu-container{flex-shrink:0;position:relative}.menu-icon{font-size:.8rem;cursor:pointer;color:var(--color-muted)}.menu-icon:hover{color:var(--color-accent)}.menu-dropdown{position:absolute;right:0;top:20px;background-color:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 2px 6px #00000026;z-index:100;display:flex;flex-direction:column;min-width:150px}.menu-dropdown button{background:none;border:none;padding:8px 12px;text-align:left;font-size:.85rem;cursor:pointer;color:var(--color-text);transition:background-color .2s}.menu-dropdown button:hover{background-color:var(--color-offwhite);color:var(--color-accent)}.migration-form{flex:1;height:100%;padding:12px;box-sizing:border-box;font-size:.95rem;display:flex;flex-direction:column;gap:24px;color:var(--color-text);font-family:var(--font-body);background-color:var(--color-white);border-radius:16px;box-shadow:var(--card-shadow);overflow:hidden}.form-title{font-size:1.4rem;font-weight:600;color:var(--color-black);font-family:var(--font-headline)}.auth-warning{background-color:#fff4f4;border-left:4px solid var(--color-accent);padding:12px;color:#500;border-radius:6px;font-size:.9rem;margin-bottom:10px}form{display:flex;flex-direction:column;gap:24px}.form-row{display:flex;flex-wrap:wrap;gap:20px}.form-card{background-color:var(--color-offwhite);padding:20px;flex:1;min-width:280px;border-radius:12px;box-shadow:var(--card-shadow);transition:background-color .2s}.form-group{margin-bottom:16px;display:flex;flex-direction:column}.form-group label{margin-bottom:6px;font-weight:500;color:var(--color-text);font-size:.9rem;font-family:var(--font-body)}.tool-select,.file-content{padding:12px;background-color:var(--color-white);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:.9rem;resize:vertical;width:100%}.file-upload-container{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-top:6px}.upload-button{display:flex;align-items:center;gap:8px;background-color:var(--color-accent);color:#fff;padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-family:var(--font-headline);transition:background-color .2s}.upload-button:hover{background-color:#a00000}.file-name{max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#666;font-size:.85rem}.file-input{display:none}textarea.file-content{font-family:Courier New,Courier,monospace;font-size:.9rem;line-height:1.4}.error-message{background-color:#fee;border-left:4px solid #cc0000;padding:12px;color:#8b0000;border-radius:6px;font-size:.9rem}.error-details{margin-top:8px;font-size:.85rem;color:#a33}.submit-button{padding:12px 20px;background-color:var(--color-accent);color:#fff;font-size:.95rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;align-self:flex-start;display:flex;align-items:center;gap:8px;transition:background-color .2s;font-family:var(--font-headline)}.submit-button:hover:not(:disabled){background-color:#a00000}.submit-button:disabled{background-color:#ddd;color:#888;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}.tool-select{padding:10px 14px;background-color:var(--color-white);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:.9rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-repeat:no-repeat;background-position:right 12px center;background-size:16px;cursor:pointer;transition:border-color .2s,background-color .2s}.tool-select:hover{background-color:var(--color-offwhite)}.tool-select:focus{outline:none;background-color:var(--color-offwhite)}.tool-select option{background-color:#fff;color:var(--color-text)}@media (max-width: 768px){.form-row{flex-direction:column}.file-name{max-width:100%}}.pipeline-yaml-viewer{border:1px solid #ddd;border-radius:6px;padding:10px}.toolbar{display:flex;justify-content:flex-end;margin-bottom:10px}.copy-all-button{background-color:var(--color-accent);color:#fff;border:none;border-radius:4px;padding:6px 12px;cursor:pointer;display:flex;align-items:center;gap:6px}.copy-all-button:hover{background-color:#ce4800}.stage-container{border-bottom:1px solid #eee;margin-bottom:8px}.stage-header{display:flex;align-items:center;justify-content:space-between;background-color:#f5f5f5;padding:6px 10px;border-radius:4px;cursor:pointer}.stage-header:hover{background-color:#e0e0e0}.stage-title{font-weight:700;flex-grow:1;margin-left:8px}.copy-button,.toggle-button{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:4px}.stage-content{background-color:#f0f0f0;padding:10px;border-radius:4px;overflow-x:auto;margin-top:4px}.event-list-container{margin-top:24px}.event-list-title{margin-bottom:16px;font-size:1.1rem;font-weight:600;color:var(--color-accent);font-family:var(--font-heading);border-bottom:1px solid var(--color-border);padding-bottom:6px}.event-list{max-height:400px;overflow-y:auto;border-radius:var(--radius-md);background-color:var(--color-light);box-shadow:var(--card-shadow);border:1px solid var(--color-border)}.event-item{padding:16px;border-bottom:1px solid var(--color-border);transition:background-color .2s;font-family:var(--font-body);color:var(--color-text);background-color:var(--color-white)}.event-item:last-child{border-bottom:none}.event-item:hover{background-color:var(--color-hover)}.event-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;cursor:pointer}.event-time{font-size:.85rem;color:var(--color-muted)}.event-status{font-size:.75rem;padding:4px 10px;border-radius:var(--radius-pill);text-transform:capitalize;background-color:var(--color-light);color:var(--color-muted)}.status-pending .event-status,.status-in-progress .event-status,.status-failed .event-status,.status-completed .event-status{background-color:var(--color-light);color:var(--color-muted)}.event-item:last-child.status-completed .event-status{background-color:#e8f5e9;color:#388e3c;font-weight:500}.event-body{margin-top:8px}.event-message{margin-bottom:6px;color:var(--color-text)}.event-tool{font-size:.85rem;color:var(--color-muted)}@media (max-width: 768px){.event-header{flex-direction:column;align-items:flex-start;gap:4px}.event-time{font-size:.8rem}}.event-left{display:flex;align-items:center;gap:12px;min-width:220px}.event-details pre{max-height:300px;overflow:auto;background-color:#f5f5f5;padding:12px;border-radius:6px;font-size:.85rem;line-height:1.3;white-space:pre-wrap;word-break:break-word;margin-top:6px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:0 2px 10px #0000000f;padding:24px;font-family:var(--font-body);color:var(--color-text)}.loading-spinner{font-size:2rem;color:var(--color-accent);animation:spin 1s linear infinite;margin-bottom:12px}.loading-message{font-size:1rem;font-family:var(--font-body);color:var(--color-text);margin:0}@keyframes spin{to{transform:rotate(360deg)}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:0 2px 10px #0000000f;padding:24px;font-family:var(--font-body);color:var(--color-text)}.error-icon{font-size:2rem;color:var(--color-accent);margin-bottom:12px}.error-message{font-size:1rem;color:var(--color-text);text-align:center;margin-bottom:16px;font-family:var(--font-body)}.error-retry-button{padding:8px 16px;background-color:var(--color-accent);color:var(--color-white);font-size:.9rem;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s ease;font-family:var(--font-body)}.error-retry-button:hover{background-color:#a80000}.migration-detail{background-color:var(--color-offwhite);border-radius:var(--radius-lg);padding:24px;margin:12px;box-shadow:var(--card-shadow);font-family:var(--font-body);display:flex;flex-direction:column;gap:24px;color:var(--color-text)}@media (max-width: 600px){.migration-detail{padding:16px;margin:8px}}.detail-header{display:flex;flex-direction:column;gap:12px}.detail-header h2{font-size:1.5rem;font-weight:600;color:var(--color-accent);margin:0;font-family:var(--font-heading)}.migration-meta{display:flex;gap:16px;flex-wrap:wrap;align-items:center;font-size:.9rem;color:var(--color-muted)}.migration-tool{background-color:var(--color-light);color:var(--color-accent);padding:4px 10px;border-radius:var(--radius-pill);font-weight:500;font-size:.75rem}.migration-time{font-style:italic;font-size:.8rem}.migration-status{padding:4px 10px;border-radius:var(--radius-pill);font-weight:600;font-size:.75rem;text-transform:capitalize;display:flex;align-items:center;gap:6px}.status-pending{background-color:#f5f5f5;color:#999}.status-in-progress{background-color:#e3f2fd;color:#1976d2}.status-completed{background-color:#e8f5e9;color:#388e3c}.status-failed{background-color:#ffebee;color:#c62828}.spinner{animation:spin 1s linear infinite;font-size:.9rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.detail-content{display:flex;flex-direction:column;gap:24px}.auth-warning{background-color:#fffbe6;border:1px solid #ffe58f;color:#ad8b00;padding:16px;border-radius:var(--radius-md);font-size:.9rem;margin-bottom:12px}.back-button{padding:8px 16px;background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background-color .2s}.back-button:hover{background-color:#a80000}.pipeline-link a{color:#1a73e8;text-decoration:none;font-weight:500}.pipeline-link a:hover{text-decoration:underline}.create-pipeline-btn{padding:10px 20px;background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;gap:8px;transition:background-color .2s,transform .1s}.create-pipeline-btn:hover{background-color:#ce4800;transform:translateY(-1px)}.create-pipeline-btn:disabled{background-color:#90caf9;cursor:not-allowed}.yaml-section{display:flex;flex-direction:column;gap:12px}.yaml-section h3{font-size:1rem;font-weight:600;color:var(--color-accent);margin:0}.yaml-viewer{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background-color:var(--color-light);box-shadow:var(--card-shadow);margin-top:12px}.yaml-toolbar{display:flex;justify-content:flex-end;padding:10px 12px;background-color:var(--color-white);border-bottom:1px solid var(--color-border)}.copy-button{display:flex;align-items:center;gap:8px;padding:6px 12px;background-color:var(--color-white);color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font-body);cursor:pointer;transition:all .25s ease}.copy-button:hover{background-color:var(--color-accent);color:#fff}.yaml-content{margin:0;padding:16px;background-color:#fafafa;overflow-x:auto;font-family:Courier New,Courier,monospace;font-size:.88rem;line-height:1.6;white-space:pre-wrap;max-height:500px;overflow-y:auto;color:#333}.header-bar{position:relative;display:flex;align-items:center;justify-content:space-between;height:64px;padding:20px;background-color:var(--color-white);font-family:var(--font-heading);box-shadow:0 2px 8px #0000000f;z-index:1000}.header-logo-title{display:flex;align-items:center;gap:4px;cursor:pointer}.header-left-logo{height:40px;width:auto;object-fit:contain}.header-text{display:flex;flex-direction:column}.header-bar-title{font-size:20px;font-weight:200;color:#ff414d;display:flex;flex-direction:column;justify-content:center}.tagline{font-size:12px;color:#5c5a5a;transform:translateY(-3px)}.header-right{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.ps-logo img{height:8.725rem;max-width:7.5rem;object-fit:contain;display:block;margin-top:3px}.header-bar-search{display:flex;justify-content:flex-end;align-items:center;min-width:200px;z-index:1}.login-link{display:flex;align-items:center}.login-modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0006;display:flex;justify-content:center;align-items:center;z-index:5000}.login-modal{background-color:#fff;padding:30px 40px;border-radius:12px;box-shadow:0 8px 24px #0003;text-align:center}.login-modal button{margin-top:20px;padding:10px 20px;font-size:16px;border:none;border-radius:8px;background-color:var(--color-accent);color:#fff;cursor:pointer}.login-modal button:hover{background-color:#e0343d}.mobile-menu-icon{display:none;font-size:1.5rem;color:var(--color-text);cursor:pointer}@media (max-width: 1024px){.mobile-menu-icon{display:block}.header-bar-title{font-size:14px}.tagline{font-size:8px}.ps-logo img{height:80px;max-width:80px}.header-bar-search{min-width:unset;flex:1}.login-link{font-size:14px}}@media (max-width: 480px){.header-bar{padding:10px}.header-right{gap:8px;justify-content:flex-end}.header-bar-search{max-width:150px}.ps-logo img{height:50px;max-width:80px}}.mobile-sidebar-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0006;z-index:2000;display:flex;justify-content:flex-start;visibility:hidden;opacity:0;transition:opacity .3s ease,visibility .3s ease}.mobile-menu-icon{color:#ff414d}.mobile-sidebar-backdrop.active{visibility:visible;opacity:1}.mobile-sidebar{background-color:var(--color-white);width:250px;max-width:100%;height:100%;padding:16px;box-shadow:2px 0 8px #0003;overflow-y:auto;position:relative;transform:translate(0);transition:transform .3s ease}.mobile-sidebar-backdrop.active .mobile-sidebar{transform:translate(0)}.mobile-sidebar-close{position:absolute;top:8px;right:8px;font-size:1.5rem;background:none;border:none;cursor:pointer;color:var(--color-text)}@media (max-width: 1024px){.desktop-sidebar{display:none}.mobile-menu-icon{display:block}}.search-container{position:relative;width:100%;max-width:400px}.search-bar{display:flex;align-items:center;background-color:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2px 12px;width:100%;max-width:400px;box-shadow:var(--card-shadow);position:relative;z-index:100}.search-bar:hover{border-color:var(--color-accent)}.search-bar input{border:none;outline:none;flex:1;font-size:1rem;font-family:var(--font-body);background-color:transparent;color:var(--color-text);transition:width .3s ease}.search-bar input::placeholder{color:var(--color-muted)}.search-icon{font-size:1rem;color:var(--color-accent);margin-right:8px}.search-suggestions{position:absolute;top:100%;left:0;width:100%;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-md);box-shadow:var(--card-shadow);max-height:250px;overflow-y:auto;z-index:2000}.suggestion-item{padding:8px 12px;cursor:pointer;transition:background .2s}.suggestion-item:hover{background:var(--color-accent-light, #f3f4f6)}@media (max-width: 480px){.search-bar{max-width:40px;padding:2px}.search-icon-container{display:flex;align-items:center;justify-content:center;width:40px}.search-bar input{width:0;opacity:0;margin-left:8px}.search-bar input.mobile-active{width:180px;opacity:1;margin-left:8px}.search-suggestions{width:90%;left:5%;transform:none}}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:100}.modal-content{background-color:#fff;padding:30px;border-radius:12px;text-align:center;width:300px;box-shadow:0 4px 12px #0003}.modal-buttons{display:flex;justify-content:space-around;margin-top:20px}.modal-btn{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-weight:700}.modal-btn.confirm{background-color:var(--color-accent);color:#fff}.modal-btn.confirm:hover{background-color:#ce4800}.modal-btn.cancel{background-color:#ccc;color:#000}.modal-btn.cancel:hover{background-color:#a09b9b;color:#000}.login-link{color:#ff414d;font-size:16px;font-weight:100;cursor:pointer;padding:5px;margin:2px}.login-link:hover{color:#000}.home-page{display:flex;flex-direction:row;align-items:stretch;background-color:var(--color-offwhite);padding:12px;box-sizing:border-box;gap:12px;min-height:calc(100vh - 64px);height:auto}.main-content{flex:1;display:flex;flex-direction:column;background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:0 2px 6px #0000000d;font-family:var(--font-body);padding:12px;margin:12px}.header-bar{height:64px}@media (max-width: 1024px){.home-page .sidebar{display:none}}@media (max-width: 768px){.home-page{flex-direction:column;height:auto}.main-content{padding:16px;margin:12px}}.migration-detail-page{background-color:var(--color-light);min-height:100vh;padding:80px 24px 24px;box-sizing:border-box;overflow-y:auto}.app-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--color-white);color:var(--color-black);font-family:var(--font-body)}.card{background-color:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;box-shadow:0 2px 6px #0000000d}.button-primary{background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 16px;font-weight:500;transition:background-color .2s}.button-primary:hover{background-color:#900}.text-muted{color:var(--color-muted)}.login-container{display:flex;flex-direction:column;align-items:center;min-height:100vh;background:#f0f2f5;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.header-bar{width:100%;max-width:100%}.login-card{display:flex;background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000001f;overflow:hidden;max-width:900px;width:100%;min-height:500px;margin-top:40px}.login-left{flex:1;background-color:#f5f5f5;display:flex;justify-content:center;align-items:center}.login-left img{width:100%;height:100%;object-fit:cover}.login-right{flex:1;display:flex;flex-direction:column;justify-content:center;padding:60px;background-color:#fff}.h1-container h1{display:flex;align-items:center;font-size:26px;color:#111;gap:2px}.h1-container h1 img{width:30px;height:30px;object-fit:contain}.login-right p{margin-bottom:30px;color:#666}.login-input{padding:14px;font-size:16px;margin-bottom:20px;border:1px solid #ccc;border-radius:8px}.login-button{padding:14px;font-size:16px;background-color:var(--color-accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease}.login-button:hover{background-color:#e0343d}.error-message{color:red;font-size:13px;margin-top:5px}.input-error{border:1px solid red}@media (max-width: 900px){.login-card{flex-direction:column;max-width:600px;padding:30px}.login-container{padding:16px}.login-left{height:200px}}@media (max-width: 480px){.h1-container h1{font-size:13px;gap:2px}.login-rignt p{font-size:8px}.h1-container h1 img{width:20px;height:20px}.login-container{padding:12px}.login-card{padding:20px}}.footer{background-color:#fff;color:#0f172a;padding:15px 30px;border-top:1px solid #e5e7eb;width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.footer-content{display:flex;flex-direction:column;align-items:flex-start}.footer-title{font-size:16px;margin:0;color:#ff414d}.footer-tagline{font-size:13px;color:#666;margin:2px 0 0}.footer-links{display:flex;gap:20px}.footer-links a{color:#ff414d;text-decoration:none;font-size:15px;transition:color .3s ease}.footer-links a:hover{color:#000}.footer-bottom{font-size:15px;color:#888;white-space:nowrap}@media (max-width: 600px){.footer{flex-direction:column;align-items:flex-start}.footer-links{margin-top:10px}}:root{--font-heading: "Futura Next", "Futura PT", sans-serif;--font-body: "Minion Pro", serif;--color-white: #ffffff;--color-offwhite: #f9f9f9;--color-black: #111111;--color-accent: #cc0000;--color-border: #e0e0e0;--color-muted: #888888;--radius-lg: 12px;--radius-md: 8px;--radius-sm: 4px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background-color:var(--color-white);color:var(--color-black);line-height:1.6;font-size:16px}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-accent);font-weight:700}a{color:var(--color-accent);text-decoration:none}button{font-family:var(--font-body);cursor:pointer}input,textarea{font-family:var(--font-body);color:var(--color-black);background-color:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px}code{font-family:monospace;background-color:var(--color-offwhite);padding:2px 4px;border-radius:var(--radius-sm)}
