:root{--sidebar-bg: #0f2d2e;--sidebar-bg-hover: #163a3c;--sidebar-active: #1a4a4d;--sidebar-text: #b8d4d6;--sidebar-text-bright: #f0fafa;--sidebar-border: rgba(255, 255, 255, .08);--sidebar-width: 260px;--main-bg: #f4f6f8;--surface: #ffffff;--surface-muted: #f8fafb;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #0d9488;--accent-hover: #0f766e;--accent-light: #ccfbf1;--accent-ring: rgba(13, 148, 136, .25);--success: #059669;--success-bg: #d1fae5;--danger: #dc2626;--danger-bg: #fee2e2;--warning: #d97706;--warning-bg: #fef3c7;--radius: 10px;--radius-sm: 6px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 4px 16px rgba(15, 23, 42, .08);--font: "DM Sans", system-ui, -apple-system, sans-serif;--mono: "SF Mono", ui-monospace, "Cascadia Code", monospace}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font);background:var(--main-bg);color:var(--text);-webkit-font-smoothing:antialiased}#app{min-height:100vh}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-brand{background:linear-gradient(145deg,#0f2d2e,#0d4a4d,#0f766e);color:var(--sidebar-text-bright);padding:3rem;display:flex;flex-direction:column;justify-content:space-between}.login-brand-mark{width:48px;height:48px;border-radius:12px;background:#ffffff26;display:grid;place-items:center;font-weight:700;font-size:1.25rem;margin-bottom:2rem}.login-brand h1{margin:0 0 .75rem;font-size:2rem;font-weight:700;letter-spacing:-.02em}.login-brand p{margin:0;font-size:1.05rem;color:#ffffffbf;line-height:1.6;max-width:360px}.login-brand-footer{font-size:.8rem;color:#ffffff73}.login-form-side{display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--surface)}.login-card{width:100%;max-width:400px}.login-card h2{margin:0 0 .35rem;font-size:1.5rem;font-weight:700}.login-card .subtitle{margin:0 0 1.75rem;color:var(--text-secondary);font-size:.95rem}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;border-right:1px solid var(--sidebar-border)}.sidebar-header{padding:1.25rem 1rem 1rem;border-bottom:1px solid var(--sidebar-border)}.sidebar-logo{display:flex;align-items:center;gap:.65rem;margin-bottom:1rem}.sidebar-logo-mark{width:36px;height:36px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;font-size:1rem}.sidebar-logo span{font-weight:700;font-size:1rem;color:var(--sidebar-text-bright)}.org-select{width:100%;padding:.5rem .65rem;border-radius:var(--radius-sm);border:1px solid var(--sidebar-border);background:#0003;color:var(--sidebar-text-bright);font:inherit;font-size:.85rem}.sidebar-nav{flex:1;padding:.75rem .5rem;overflow-y:auto}.nav-section-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;padding:.75rem .75rem .35rem}.nav-item{display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;border-radius:var(--radius-sm);font-size:.88rem;color:var(--sidebar-text);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit;transition:background .12s}.nav-item:hover{background:var(--sidebar-bg-hover);color:var(--sidebar-text-bright)}.nav-item.active{background:var(--sidebar-active);color:var(--sidebar-text-bright);box-shadow:inset 3px 0 0 var(--accent)}.nav-icon{width:18px;text-align:center;opacity:.7;font-size:.95rem}.nav-item.active .nav-icon{opacity:1}.nav-item:disabled{opacity:.4;cursor:not-allowed}.nav-item:disabled:hover{background:none;color:var(--sidebar-text)}.sidebar-footer{padding:1rem;border-top:1px solid var(--sidebar-border)}.sandbox-badge-side{display:flex;align-items:center;gap:.5rem;padding:.5rem .65rem;border-radius:var(--radius-sm);background:#0d948826;border:1px solid rgba(13,148,136,.3);font-size:.75rem;font-weight:600;color:#5eead4;margin-bottom:.75rem}.sandbox-dot{width:7px;height:7px;border-radius:50%;background:#2dd4bf;box-shadow:0 0 6px #2dd4bf}.user-card{display:flex;align-items:center;gap:.65rem}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:.75rem;font-weight:700;flex-shrink:0}.user-info strong{display:block;font-size:.82rem;color:var(--sidebar-text-bright)}.user-info span{font-size:.72rem;color:var(--sidebar-text);opacity:.8}.main-area{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.main-header{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:1rem}.breadcrumb{font-size:.85rem;color:var(--text-muted)}.breadcrumb a{color:var(--accent);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.header-actions{display:flex;align-items:center;gap:.5rem}.icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;display:grid;place-items:center;font-size:1rem}.icon-btn:hover{background:var(--surface-muted)}.page-content{flex:1;padding:1.5rem 1.75rem 6rem}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-title-block h1{margin:0 0 .35rem;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}.page-meta{font-size:.85rem;color:var(--text-secondary)}.page-meta span+span:before{content:"·";margin:0 .4rem;color:var(--text-muted)}.gate-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:999px;font-size:.78rem;font-weight:600;background:var(--success-bg);color:var(--success);border:1px solid rgba(5,150,105,.2)}.gate-pill.pending{background:var(--warning-bg);color:var(--warning);border-color:#d9770633}.env-pill{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.68rem;font-weight:700;letter-spacing:.06em;background:var(--accent-light);color:var(--accent-hover);vertical-align:middle}.stepper{display:flex;align-items:flex-start;gap:0;margin-bottom:1.75rem;overflow-x:auto;padding:6px 0 .25rem}.stepper-item{display:flex;align-items:center;flex:1;min-width:120px}.stepper-node{display:flex;flex-direction:column;align-items:center;gap:.4rem;flex-shrink:0}.stepper-circle{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-strong);background:var(--surface);color:var(--text-muted);display:grid;place-items:center;font-size:.8rem;font-weight:600;transition:all .15s}.stepper-item.done .stepper-circle{background:var(--accent);border-color:var(--accent);color:#fff}.stepper-item.active .stepper-circle{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-ring);position:relative;z-index:1}.stepper-label{font-size:.72rem;color:var(--text-muted);text-align:center;max-width:90px;line-height:1.3}.stepper-item.active .stepper-label{color:var(--accent);font-weight:600}.stepper-item.done .stepper-label{color:var(--text-secondary)}.stepper-line{flex:1;height:2px;background:var(--border);margin:0 .25rem 1.4rem;min-width:24px}.stepper-item.done .stepper-line{background:var(--accent)}.stepper-item:last-child .stepper-line{display:none}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.panel-header h2{margin:0;font-size:.95rem;font-weight:600}.panel-body{padding:1.25rem}.panel-body-flush{padding:0}.split-layout{display:grid;grid-template-columns:1fr 380px;gap:1rem;align-items:start}.field{margin-bottom:1.1rem}.field:last-child{margin-bottom:0}.field label,.field-label{display:block;font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-bottom:.4rem}.field .hint{font-size:.78rem;color:var(--text-muted);margin-top:.3rem;line-height:1.45}input,select,textarea{width:100%;padding:.6rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font:inherit;font-size:.9rem;transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}textarea{min-height:88px;resize:vertical}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mapping-table{width:100%;border-collapse:collapse;font-size:.85rem}.mapping-table th{text-align:left;padding:.65rem 1rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--surface-muted);border-bottom:1px solid var(--border)}.mapping-table td{padding:.6rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.mapping-table tr:last-child td{border-bottom:none}.mapping-table tr:hover td{background:var(--surface-muted)}.field-name{font-weight:600;font-size:.85rem}.field-name .required{color:var(--danger)}.field-key{font-size:.72rem;color:var(--text-muted);font-family:var(--mono);margin-top:.15rem}.field-arrow{color:var(--text-muted);text-align:center;font-size:1rem}.type-badge{display:inline-block;padding:.15rem .45rem;border-radius:4px;font-size:.7rem;font-weight:600;background:var(--surface-muted);color:var(--text-secondary);font-family:var(--mono)}.mapping-input{font-family:var(--mono);font-size:.82rem!important;padding:.45rem .6rem!important}.json-panel{position:sticky;top:72px}.json-panel .panel-header select{width:auto;padding:.3rem .5rem;font-size:.8rem}.code-block{background:#1e293b;color:#e2e8f0;font-family:var(--mono);font-size:.78rem;line-height:1.55;padding:1rem;margin:0;overflow:auto;max-height:480px;white-space:pre-wrap;word-break:break-word}.btn-copy{padding:.3rem .65rem;font-size:.78rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;font-weight:500}.btn-copy:hover{background:var(--surface-muted)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.option-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem;cursor:pointer;transition:border-color .12s,box-shadow .12s;background:var(--surface)}.option-card:hover:not(.disabled){border-color:var(--accent);box-shadow:var(--shadow-sm)}.option-card.selected{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 1px var(--accent)}.option-card.disabled{opacity:.55;cursor:not-allowed}.option-card h3{margin:0 0 .3rem;font-size:.9rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.option-card p{margin:0;font-size:.8rem;color:var(--text-secondary);line-height:1.4}.status-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.12rem .4rem;border-radius:4px}.status-badge.available{background:var(--success-bg);color:var(--success)}.status-badge.coming_soon{background:#dbeafe;color:#1d4ed8}.status-badge.planned{background:var(--surface-muted);color:var(--text-muted)}.section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:1.25rem 0 .6rem}.section-title:first-child{margin-top:0}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.88rem;line-height:1.45}.alert-error{background:var(--danger-bg);border:1px solid rgba(220,38,38,.2);color:#991b1b}.alert-success{background:var(--success-bg);border:1px solid rgba(5,150,105,.2);color:#065f46}.alert-info{background:var(--accent-light);border:1px solid rgba(13,148,136,.2);color:var(--accent-hover)}.test-result{margin-top:1rem;padding:1rem;border-radius:var(--radius-sm);background:#1e293b;color:#86efac;font-family:var(--mono);font-size:.78rem;white-space:pre-wrap;word-break:break-word}.test-result.error{background:var(--danger-bg);color:#991b1b}button{font:inherit;cursor:pointer}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;border:none;transition:background .12s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border-strong)}.btn-secondary:hover{background:var(--surface-muted)}.btn-ghost{background:transparent;color:var(--text-muted);border:none;padding:.55rem .75rem}.btn-ghost:hover{color:var(--text)}.btn-sm{padding:.4rem .75rem;font-size:.82rem}.btn-row{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:1rem}.wizard-footer{position:fixed;bottom:0;left:var(--sidebar-width);right:0;height:64px;background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.75rem;z-index:50;box-shadow:0 -2px 8px #0f172a0a}.footer-progress{display:flex;flex-direction:column;align-items:center;gap:.3rem;min-width:200px}.footer-progress span{font-size:.78rem;color:var(--text-muted);font-weight:500}.progress-bar{width:200px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .2s}.footer-actions{display:flex;gap:.65rem}.summary-list{list-style:none;margin:0;padding:0}.summary-list li{display:flex;justify-content:space-between;padding:.65rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.summary-list li:last-child{border-bottom:none}.summary-list .label{color:var(--text-secondary)}.summary-list .value{font-weight:600;text-align:right}.preview-frame-wrap{width:min(360px,100%);margin:0 auto;aspect-ratio:360 / 540;border:1px solid var(--border);border-radius:var(--radius-sm);background:#0d5c28;overflow:hidden;box-shadow:var(--shadow-sm)}.preview-frame{display:block;width:100%;height:100%;border:0;background:#0d5c28}.preview-frame-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:200px;padding:1.5rem;text-align:center;color:#ecfdf5;font-size:.875rem;background:radial-gradient(ellipse at 50% 0%,#166534 0%,transparent 55%),linear-gradient(165deg,#052e16,#0b5e2b 45%,#064e3b)}@media(max-width:1024px){.split-layout{grid-template-columns:1fr}.json-panel{position:static}}@media(max-width:768px){.login-page{grid-template-columns:1fr}.login-brand,.sidebar{display:none}.main-area{margin-left:0}.wizard-footer{left:0;padding:0 1rem}.footer-progress{display:none}.form-grid-2{grid-template-columns:1fr}.stepper-label{display:none}}
