@import"https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;700&family=Roboto+Slab:wght@400;700&display=swap";body{font-family:Roboto,sans-serif;font-weight:300;background:#fff;color:#333;min-height:100vh;display:flex;flex-direction:column}.nav{position:sticky;top:0;z-index:100;background:#fff;border-bottom:3px solid #ff9900;box-shadow:0 2px 12px #0000000f;padding:1rem 2rem}.nav-inner{width:80%;max-width:1600px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.nav-logo img{height:28px;display:block}.nav-links{display:flex;align-items:center;gap:2rem}.nav-link{font-family:Roboto,sans-serif;font-size:.82rem;font-weight:700;color:#888;text-decoration:none;letter-spacing:.02em;transition:color .15s;white-space:nowrap}.nav-link:hover{color:#333}.nav-link--cta{color:#f90;border:1.5px solid #ff9900;padding:.38rem .9rem;border-radius:6px}.nav-link--cta:hover{background:#f90;color:#fff}.nav-signout{font-family:Roboto,sans-serif;font-size:.82rem;font-weight:700;color:#888;background:none;border:none;cursor:pointer;letter-spacing:.02em;padding:0;transition:color .15s;white-space:nowrap}.nav-signout:hover{color:#333}.card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:2rem;box-shadow:0 2px 12px #0000000d;transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.72rem 1.6rem;border-radius:7px;font-family:Roboto,sans-serif;font-size:.88rem;font-weight:700;text-decoration:none;letter-spacing:.02em;cursor:pointer;border:none;transition:all .18s;white-space:nowrap}.btn-primary{background:#f90;color:#fff;box-shadow:0 2px 12px #ff990047}.btn-primary:hover{background:#e68800}.btn-primary:disabled{background:#ccc;box-shadow:none;cursor:not-allowed}.btn-secondary{background:#f2f2f2;color:#555;border:1px solid #e0e0e0}.btn-secondary:hover{background:#e8e8e8}.btn-ghost{background:transparent;color:#666;padding:.4rem .8rem;font-size:.8rem}.btn-ghost:hover{background:#f5f5f5}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.82rem;font-weight:600;color:#444;margin-bottom:.4rem;letter-spacing:.02em}.form-label .optional{font-weight:400;color:#999;font-size:.75rem}.form-input,.form-textarea{width:100%;padding:.65rem .9rem;border:1px solid #ddd;border-radius:7px;font-size:.9rem;color:#333;background:#fff;transition:border-color .18s,box-shadow .18s;font-family:inherit}.form-input:focus,.form-textarea:focus{outline:none;border-color:#f90;box-shadow:0 0 0 3px #ff99001f}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-hint{font-size:.75rem;color:#999;margin-top:.3rem}.hero{width:80%;max-width:1600px;margin:0 auto;padding:6rem 2rem 5rem}.hero-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#f90;margin-bottom:1rem}.hero-title{font-family:Roboto Slab,serif;font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;color:#222;line-height:1.1;margin-bottom:1.5rem;max-width:680px}.hero-desc{font-size:1.05rem;font-weight:300;color:#555;max-width:560px;line-height:1.75;margin-bottom:2.75rem}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}hr.divider{width:80%;max-width:1600px;margin:0 auto;border:none;border-top:1px solid #e8e8e8}.cards-section{width:80%;max-width:1600px;margin:0 auto;padding:4rem 2rem 5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.card-tag{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#f90;margin-bottom:.75rem}.card-title{font-family:Roboto Slab,serif;font-size:1.2rem;font-weight:700;color:#222;margin-bottom:.6rem}.card-desc{font-size:.88rem;font-weight:300;color:#666;line-height:1.65;flex:1;margin-bottom:1.5rem}.card-link{font-size:.8rem;font-weight:700;color:#f90;text-decoration:none;letter-spacing:.02em;transition:color .15s}.card-link:hover{color:#e68800}.card-link--muted{color:#bbb}.card-link--muted:hover{color:#999}footer{margin-top:auto;border-top:1px solid #e8e8e8;padding:1.5rem 2rem;text-align:center;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#ccc}.page{width:80%;max-width:1600px;margin:0 auto;padding:3rem 2rem 5rem}.page-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#f90;margin-bottom:.5rem}.page-title{font-family:Roboto Slab,serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;color:#222;margin-bottom:.5rem}.page-desc{font-size:.95rem;color:#777;margin-bottom:3rem;font-weight:300}.state-msg{text-align:center;padding:4rem 2rem;color:#aaa;font-size:.92rem}.brand-group{margin-bottom:2.5rem}.brand-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.brand-name{font-family:Roboto Slab,serif;font-size:1.05rem;font-weight:700;color:#333}.brand-count{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#bbb}.file-list{display:flex;flex-direction:column;gap:.5rem}.file-row{background:#fff;border:1px solid #e8e8e8;border-radius:10px;padding:.85rem 1.25rem;display:flex;align-items:center;gap:1rem;transition:border-color .15s,box-shadow .15s}.file-row:hover{border-color:#f90;box-shadow:0 2px 10px #ff99001a}.file-type-badge{flex-shrink:0;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.22rem .55rem;border-radius:4px;color:#fff}.badge-report{background:#0078d4}.badge-plan{background:#f90}.badge-unknown{background:#aaa}.file-meta{flex:1;min-width:0}.file-date{font-size:.88rem;font-weight:700;color:#333}.file-name{font-size:.72rem;color:#bbb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.1rem}.file-link{flex-shrink:0;font-size:.78rem;font-weight:700;color:#f90;text-decoration:none;padding:.4rem .9rem;border:1.5px solid #ff9900;border-radius:6px;transition:background .15s,color .15s;white-space:nowrap}.file-link:hover{background:#f90;color:#fff}.file-delete{flex-shrink:0;font-size:.78rem;font-weight:700;color:#ccc;background:none;border:1.5px solid #e8e8e8;border-radius:6px;padding:.4rem .75rem;cursor:pointer;font-family:Roboto,sans-serif;white-space:nowrap;transition:color .15s,border-color .15s}.file-delete:hover{color:#e53935;border-color:#e53935}.file-delete:disabled{opacity:.4;cursor:default}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#f5f5f5;display:flex;align-items:center;justify-content:center;z-index:200}.login-box{background:#fff;border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:360px;box-shadow:0 8px 40px #0000002e}.login-header{text-align:center;margin-bottom:1.75rem}.login-logo{height:32px;margin-bottom:.75rem}.login-subtitle{font-size:.85rem;color:#888}.login-label{display:block;font-size:.8rem;font-weight:600;color:#555;margin-bottom:.35rem}.login-input{width:100%;padding:.6rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;font-family:inherit;margin-bottom:1rem;transition:border-color .15s}.login-input:focus{outline:none;border-color:#f90;box-shadow:0 0 0 3px #ff99001f}.login-input.error{border-color:#e53935}.login-error{color:#e53935;font-size:.82rem;margin:-.5rem 0 1rem}.login-btn{width:100%;padding:.72rem;background:#222;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s}.login-btn:hover{background:#f90}.page-footer{margin-top:4rem;padding-top:1.5rem;border-top:1px solid #e8e8e8;text-align:center;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#ccc}.filter-wrap{margin-bottom:2rem}.filter-input{width:100%;max-width:420px;padding:.6rem .85rem;border:1px solid #ddd;border-radius:7px;font-size:.92rem;font-family:Roboto,sans-serif;font-weight:300;color:#333;background:#fff;transition:border-color .15s,box-shadow .15s}.filter-input:focus{outline:none;border-color:#f90;box-shadow:0 0 0 3px #ff99001f}.filter-input::placeholder{color:#bbb}.rerun-btn{display:none;flex-shrink:0;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#f90;background:none;border:1.5px solid #ff9900;border-radius:6px;padding:.28rem .7rem;cursor:pointer;font-family:Roboto,sans-serif;transition:background .15s,color .15s}.rerun-btn:hover{background:#f90;color:#fff}.rr-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:300;opacity:0;transition:opacity .2s;pointer-events:none}.rr-backdrop.visible{opacity:1;pointer-events:auto}.rr-box{background:#fff;border-radius:14px;padding:2rem 2rem 1.5rem;width:100%;max-width:420px;box-shadow:0 12px 48px #00000038;transform:translateY(12px);transition:transform .2s}.rr-backdrop.visible .rr-box{transform:translateY(0)}.rr-header{margin-bottom:1.5rem}.rr-title{font-family:Roboto Slab,serif;font-size:1.1rem;font-weight:700;color:#222;margin-bottom:.25rem}.rr-brand{font-size:.85rem;color:#888;font-weight:300}.rr-meta-form{margin-bottom:1.25rem}.rr-meta-form p{font-size:.82rem;color:#666;margin-bottom:.85rem;line-height:1.5}.rr-meta-label{display:block;font-size:.75rem;font-weight:600;color:#555;margin-bottom:.3rem}.rr-meta-input{width:100%;padding:.55rem .7rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;font-family:inherit;margin-bottom:.75rem;transition:border-color .15s}.rr-meta-input:focus{outline:none;border-color:#f90;box-shadow:0 0 0 3px #ff99001f}.rr-pipeline{display:flex;flex-direction:column;gap:0;margin-bottom:1.25rem}.rr-step{display:flex;align-items:center;gap:.75rem;position:relative}.rr-step-left{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0}.rr-node{width:18px;height:18px;border-radius:50%;border:2px solid #ddd;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s,background .2s;font-size:9px;color:#fff;font-weight:700}.rr-node.running{border-color:#f90;animation:rr-spin .8s linear infinite}.rr-node.done{border-color:#086171;background:#086171}.rr-node.error{border-color:#e03271;background:#e03271}.rr-connector{width:2px;height:28px;background:#e8e8e8;margin:1px 0;position:relative;overflow:hidden;transition:background .3s}.rr-connector.active{background:#f90}.rr-connector.done{background:#086171}.rr-flow-dot{position:absolute;width:4px;height:4px;border-radius:50%;left:-1px;background:#f90;animation:rr-flow 1.3s ease-in-out infinite}.rr-flow-dot:nth-child(2){animation-delay:.43s}.rr-flow-dot:nth-child(3){animation-delay:.86s}.rr-step-body{flex:1;padding:4px 0}.rr-step-label{font-size:.85rem;font-weight:400;color:#444}.rr-step-label.active{font-weight:700;color:#333}.rr-step-score{font-size:.72rem;font-weight:700;color:#086171;margin-left:.4rem}.rr-step-status{font-size:.72rem;color:#bbb;margin-left:auto;flex-shrink:0}.rr-step-status.running{color:#f90}.rr-step-status.done{color:#086171}.rr-step-status.error{color:#e03271}.rr-error-msg{font-size:.8rem;color:#e03271;background:#fff0f4;border:1px solid #f9c0d0;border-radius:6px;padding:.6rem .85rem;margin-bottom:1rem;display:none}.rr-footer{display:flex;gap:.75rem;justify-content:flex-end}.rr-btn{font-size:.82rem;font-weight:700;border-radius:6px;padding:.55rem 1.1rem;cursor:pointer;font-family:inherit;transition:background .15s,color .15s;border:none}.rr-btn-cancel{background:#f0f0f0;color:#555}.rr-btn-cancel:hover{background:#e0e0e0}.rr-btn-view{background:#f90;color:#fff;display:none}.rr-btn-view:hover{background:#e08800}.rr-btn-start{background:#222;color:#fff}.rr-btn-start:hover{background:#f90}@keyframes rr-spin{to{transform:rotate(360deg)}}@keyframes rr-flow{0%{top:0%;opacity:0}15%{opacity:1}85%{opacity:1}to{top:100%;opacity:0}}.app{min-height:100vh;display:flex;flex-direction:column}.step-bar{background:#f9f9f9;border-bottom:1px solid #ececec;padding:.65rem 2rem}.step-bar-inner{width:80%;max-width:1600px;margin:0 auto;display:flex;align-items:center;justify-content:center}.step-indicator{display:flex;align-items:center;gap:0}.step-dot{width:28px;height:28px;border-radius:50%;background:#e0e0e0;color:#999;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s}.step-dot.active{background:#f90;color:#fff}.step-dot.done{background:#43a047;color:#fff}.step-line{width:24px;height:2px;background:#e0e0e0}.app-main{flex:1;padding:2rem;width:80%;max-width:1600px;margin:0 auto}.app-footer{background:#f2f2f2;border-top:1px solid #e0e0e0;padding:1rem 2rem;text-align:center;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#aaa}@media (max-width: 768px){.nav{padding:.75rem 1rem}.nav-inner{width:100%}.nav-links{gap:1rem}.nav-link--cta{display:none}.hero{width:100%;padding:3rem 1.25rem 2.5rem}hr.divider{width:100%}.cards-section{width:100%;padding:2.5rem 1.25rem 3rem}.page{width:100%;padding:1.5rem 1rem 3rem}.file-row{flex-wrap:wrap;align-items:flex-start;gap:.4rem .6rem;padding:.75rem 1rem}.file-meta{order:3;flex-basis:100%}.file-link{margin-left:auto}}.brand-form-intro{display:flex;align-items:flex-start;gap:1.25rem}.intro-icon{font-size:2rem;flex-shrink:0;line-height:1;margin-top:.1rem}.intro-title{font-size:1.15rem;font-weight:700;color:#333;margin-bottom:.4rem}.intro-desc{font-size:.88rem;color:#666;line-height:1.6}.brand-name-input{font-size:1.1rem;padding:.8rem 1rem}.required-star{color:#e53935}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;padding-right:2.2rem;cursor:pointer}.form-actions{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #f0f0f0}.runner-intro{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.intro-title{font-size:1.1rem;font-weight:700;color:#222;margin-bottom:.4rem}.intro-desc{font-size:.875rem;color:#666;line-height:1.5}.prompt-preview-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.prompt-preview-title{font-weight:600;font-size:.9rem;color:#444}.prompt-preview-toggle{font-size:.78rem;color:#f90;font-weight:600}.prompt-preview-body{margin-top:1rem;padding-top:1rem;border-top:1px solid #f0f0f0}.prompt-text{background:#f8f8f8;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;font-size:.78rem;line-height:1.6;font-family:Segoe UI,system-ui,monospace;white-space:pre-wrap;word-break:break-word;color:#444;max-height:400px;overflow-y:auto}.platforms-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.platform-card{border-left:4px solid var(--platform-color);padding:0;overflow:hidden}.platform-card.done{background:#fafff9}.platform-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;gap:1rem}.platform-header-left{display:flex;align-items:center;gap:.75rem}.platform-num{width:24px;height:24px;border-radius:50%;background:#f0f0f0;font-size:.72rem;font-weight:700;color:#666;display:flex;align-items:center;justify-content:center}.platform-name{font-weight:700;font-size:.95rem}.platform-status{display:flex;align-items:center;gap:.5rem}.status-running{font-size:.82rem;color:#888}.status-error{font-size:.82rem;color:#e53935;max-width:400px}.done-badge{background:#e8f5e9;color:#2e7d32;font-size:.68rem;font-weight:700;letter-spacing:.06em;padding:.15rem .5rem;border-radius:99px;text-transform:uppercase}.runner-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem}.runner-footer-right{display:flex;align-items:center;gap:1rem}.runner-footer-hint{font-size:.82rem;color:#999}.inline-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,0,0,.15);border-top-color:#f90;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;flex-shrink:0}.report-intro{display:flex;align-items:center;justify-content:space-between;gap:1.25rem}.section-mini-title{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#999;margin-bottom:1rem}.platform-summary-grid{display:flex;flex-direction:column;gap:.5rem}.platform-summary-item{display:flex;align-items:center;gap:.75rem;font-size:.88rem}.ps-dot{width:10px;height:10px;border-radius:50%;background:var(--pc);flex-shrink:0}.ps-name{flex:1;font-weight:600;color:#444}.ps-chars{color:#999;font-size:.78rem}.api-key-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.api-key-title{font-weight:600;font-size:.9rem;color:#444}.api-key-body{margin-top:1rem;padding-top:1rem;border-top:1px solid #f0f0f0}.api-key-desc{font-size:.82rem;color:#666;margin-bottom:.75rem;line-height:1.55}.api-key-input-row{display:flex;gap:.75rem;align-items:center;margin-bottom:.5rem}.generate-action{display:flex;flex-direction:column;align-items:flex-start;gap:1rem}.generate-desc{font-size:.88rem;color:#666;line-height:1.55}.generate-btn{font-size:1rem;padding:.75rem 2rem;flex-shrink:0}.generating-card{display:flex;align-items:center;gap:1.5rem}.generating-spinner{width:36px;height:36px;border:3px solid #f0f0f0;border-top-color:#f90;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.generating-title{font-weight:700;font-size:.95rem;color:#333;margin-bottom:.3rem}.generating-desc{font-size:.82rem;color:#888;line-height:1.5}.error-card{display:flex;align-items:flex-start;gap:1rem;border-left:4px solid #e53935}.error-icon{font-size:1.5rem;flex-shrink:0}.error-title{font-weight:700;color:#c62828;margin-bottom:.5rem}.error-pre{font-family:Segoe UI,system-ui,monospace;font-size:.78rem;line-height:1.6;color:#555;background:#fdf3f3;border:1px solid #f5c6c6;border-radius:6px;padding:.75rem 1rem;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;margin:0}.report-actions-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.report-success{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:#444}.success-icon{font-size:1.2rem}.report-actions{display:flex;align-items:center;gap:.75rem}.report-section-header{display:flex;align-items:flex-start;gap:1rem;margin:2rem 0 1rem;padding-bottom:.75rem;border-bottom:2px solid #ff9900}.report-section-num{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#f90;background:#fff4e0;border:1px solid #ffe0a0;border-radius:6px;padding:.25rem .6rem;flex-shrink:0;margin-top:.15rem}.report-section-title{font-size:1.05rem;font-weight:700;color:#333;margin-bottom:.15rem}.report-section-desc{font-size:.82rem;color:#888;line-height:1.5}.plan-hint{color:#aaa;font-style:italic}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#f5f5f5;color:#333;min-height:100vh}#root{min-height:100vh}
