:root{color:#172033;background:#f8fafc;--app-bg: #f8fafc;--panel: #ffffff;--panel-soft: #fbfdff;--line: #e5e7eb;--line-strong: #dbe3ee;--shadow: 0 4px 20px rgba(0, 0, 0, .03);--shadow-hover: 0 8px 28px rgba(15, 23, 42, .055);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--app-bg);overflow-x:hidden}#root,.app-shell,.shell-main,.content-area{max-width:100%;overflow-x:hidden}button,input{font:inherit}button:disabled{cursor:not-allowed;opacity:.58}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:264px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:24px}.brand-block{display:flex;align-items:center;gap:12px}.sidebar-close{margin-left:auto}.brand-mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#0f766e)}.brand-block strong,.top-header strong{display:block;color:#0f172a;overflow-wrap:anywhere}.brand-block span,.top-header span{color:#64748b;font-size:13px}.side-nav{display:grid;gap:8px}.side-nav a{display:flex;align-items:center;gap:10px;min-height:44px;padding:10px 12px;border-radius:10px;color:#475569}.side-nav a.active,.side-nav a:hover{background:#eef5ff;color:#1d4ed8}.operator-boundary{margin-top:auto;display:flex;gap:10px;padding:12px;border:1px solid #dbeafe;border-radius:12px;color:#1e3a8a;background:#eff6ff;font-size:13px}.shell-main{min-width:0;display:flex;flex-direction:column}.top-header{position:sticky;top:0;z-index:5;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:#f8fafce6;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.header-actions{display:flex;gap:10px;align-items:center;flex-shrink:0;min-width:0}.header-title{flex:1 1 auto;min-width:0}.session-pill{max-width:180px;min-height:34px;display:inline-flex;align-items:center;padding:0 10px;border-radius:999px;color:#075985;background:#e0f2fe;font-size:13px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content-area{width:min(1180px,100%);margin:0 auto;padding:28px}.page-stack{display:grid;gap:22px}.topbar-section{display:flex;align-items:center;justify-content:space-between;gap:18px}.topbar-section h1{margin:4px 0 0;color:#0f172a;font-size:30px;line-height:1.15}.page-eyebrow{color:#2563eb;font-size:13px;font-weight:800;text-transform:uppercase}.topbar-status{display:inline-flex;align-items:center;gap:10px;color:#64748b;font-size:13px;white-space:nowrap}.dot{width:8px;height:8px;border-radius:999px;background:#16a34a}.page-heading span{color:#2563eb;font-size:13px;font-weight:700;text-transform:uppercase}.page-heading h1,.hero-panel h1{margin:6px 0 8px;color:#0f172a;font-size:34px;line-height:1.15;overflow-wrap:anywhere}.page-heading p,.hero-panel p,.section-card-header p{margin:0;color:#64748b}.page-heading.compact h1{font-size:30px}.page-heading.compact p{max-width:720px}.hero-panel,.section-card,.metric-card{border:1px solid var(--line);border-radius:16px;background:var(--panel);box-shadow:var(--shadow)}.hero-panel:hover,.section-card:hover,.metric-card:hover{box-shadow:var(--shadow-hover)}.hero-panel{padding:30px}.hero-panel.login-state h1{max-width:780px;font-size:38px;line-height:1.18}.hero-panel.login-state p{max-width:760px;line-height:1.65}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}.section-card{padding:22px}.section-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.section-card-header h2{margin:0 0 6px;font-size:20px;color:#0f172a}.section-card-header p,.state-shell span,.result-copy span,.watch-card span,.info-row span{overflow-wrap:anywhere}.section-card-action{flex-shrink:0}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr))}.grid2,.grid3,.grid4{display:grid;gap:14px}.grid2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid4{grid-template-columns:repeat(4,minmax(0,1fr))}.filters{display:flex;align-items:center;gap:12px;margin-bottom:16px}.select,.input{min-height:44px;border:1px solid #cbd5e1;border-radius:10px;padding:0 12px;color:#475569;background:#fff}.field-label{display:block;margin:8px 0;color:#475569;font-size:13px;font-weight:700}.metric-card{padding:18px}.summary-tile{min-height:92px;padding:16px;border:1px solid var(--line);border-radius:14px;background:#f8fafc}.summary-tile span,.summary-tile strong{display:block}.summary-tile span{color:#64748b;font-size:13px}.summary-tile strong{margin-top:10px;color:#0f172a;font-size:24px}.compact-summary{margin-top:14px}.metric-card span,.result-card span,.watch-card span,.info-row span{color:#64748b;font-size:13px}.metric-card strong{display:block;margin-top:8px;font-size:30px;color:#0f172a}.metric-card small{color:#94a3b8}.state-metric strong{font-size:24px}.primary-button,.secondary-button,.ghost-button,.icon-button{min-height:42px;border:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:700}.wide{width:100%}.primary-button{padding:0 16px;color:#fff;background:#2563eb}.kakao-button{min-width:180px;justify-content:center}.secondary-button{padding:0 14px;color:#1d4ed8;background:#eff6ff}.ghost-button,.icon-button{padding:0 12px;color:#334155;background:#fff;border:1px solid #dbe3ef;white-space:nowrap}.ghost-button.warning{color:#b45309;background:#fffbeb;border-color:#fde68a}.mobile-only{display:none}.status-badge{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;font-size:12px;font-weight:800;color:#334155;background:#f1f5f9}.status-badge.success{color:#047857;background:#d1fae5}.status-badge.warning{color:#b45309;background:#fef3c7}.status-badge.danger{color:#b91c1c;background:#fee2e2}.status-badge.has-match{color:#6d28d9;background:#f3e8ff}.status-badge.ready{color:#374151;background:#f3f4f6}.status-badge.pending{color:#92400e;background:#fef3c7}.status-badge.active{color:#166534;background:#dcfce7}.status-badge.disabled{color:#4b5563;background:#f3f4f6}.status-badge.failed{color:#991b1b;background:#fee2e2}.status-badge.incomplete{color:#7c2d12;background:#ffedd5}.search-shell,.detail-placeholder,.placeholder-card{min-height:56px;display:flex;align-items:center;gap:10px;padding:14px;border:1px dashed #cbd5e1;border-radius:12px;color:#64748b;background:#f8fafc}.search-input-wrap{min-height:48px;display:flex;align-items:center;gap:10px;padding:0 14px;border:1px solid #cbd5e1;border-radius:12px;background:#fff}.search-input-wrap input{min-width:0;width:100%;border:0;outline:0;color:#0f172a;background:transparent}.search-result-list{display:grid;gap:8px;margin-top:12px}.table-card-list{display:grid;gap:8px}.search-result-button,.preset-card,.workflow-item{border:1px solid var(--line-strong);border-radius:14px;background:var(--panel);color:#172033;text-align:left}.search-result-button{min-height:56px;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px}.search-result-button.selected,.preset-card.selected{border-color:#2563eb;background:#eff6ff;box-shadow:inset 0 0 0 1px #2563eb29}.search-result-button small{color:#64748b}.selected-chip-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.selected-chip{min-height:44px;display:inline-flex;align-items:center;gap:8px;padding:7px 8px 7px 13px;border:1px solid #bfdbfe;border-radius:999px;color:#1e3a8a;background:#eff6ff}.selected-chip small{color:#64748b}.selected-chip button{width:30px;height:30px;border:0;border-radius:999px;display:grid;place-items:center;color:#dc2626;background:transparent}.selected-chip button:hover{background:#dbeafe}.selected-stock-panel{display:grid;gap:10px}.stock-chip-wide{width:100%;justify-content:space-between;border-radius:14px}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.chip-button{min-height:34px;border:0;border-radius:999px;padding:0 12px;color:#475569;background:#f1f5f9;font-weight:800;cursor:pointer}.chip-button.on{color:#1d4ed8;background:#eff6ff}.summary-list,.disabled-setting-list{display:grid;gap:10px}.summary-row,.disabled-setting-list span{min-height:42px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;border:1px solid var(--line);border-radius:12px;color:#475569;background:#f8fafc}.summary-row strong{color:#0f172a}.subsection-title{margin:18px 0 10px;color:#0f172a;font-size:15px}.chip-row.compact{margin-top:10px}.stock-chip{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;color:#1e3a8a;background:#dbeafe;font-weight:700;font-size:13px}.placeholder-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.two-column-grid,.preset-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.preset-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.builder,.strategy-builder-grid{display:grid;grid-template-columns:.8fr 1.4fr .8fr;gap:18px}.action-row{grid-column:2 / 4;display:grid;grid-template-columns:1fr 1fr;gap:18px}.preset-card{min-height:136px;padding:16px;cursor:pointer}.preset-card strong{display:block;margin-bottom:8px}.preset-card span{display:block;color:#64748b;font-size:13px;line-height:1.45}.mini-chip{display:inline-flex;min-height:26px;align-items:center;padding:0 8px;border-radius:999px;color:#1d4ed8;background:#dbeafe;font-size:12px;font-weight:700}.workflow-list{display:grid;gap:10px}.workflow-item{display:flex;gap:12px;padding:14px}.workflow-item strong,.workflow-item span{display:block}.workflow-item span{margin-top:3px;color:#64748b;font-size:13px}.result-list,.watch-list{display:grid;gap:12px}.result-list.grouped{gap:14px}.group-heading{display:flex;align-items:center;gap:8px;color:#047857}.result-card,.watch-card,.info-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px;border:1px solid #e2e8f0;border-radius:14px;background:#fbfdff}.result-card{align-items:stretch}.result-success{border-color:#86efac;background:#f0fdf4}.result-failure{border-color:#fecaca;background:#fff7f7}.result-primary{min-width:112px;display:grid;align-content:center;gap:8px}.result-primary strong{font-size:30px;color:#0f172a}.result-copy{min-width:0;flex:1}.result-card h3,.watch-card h3{margin:8px 0 4px;color:#0f172a;font-size:16px;overflow-wrap:anywhere}.watch-card{justify-content:flex-start;cursor:default}button.watch-card{width:100%;text-align:left;cursor:pointer}.watch-warning{border-color:#fde68a;background:#fffbeb}.watch-danger{border-color:#fecaca;background:#fff7f7}.watch-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#2563eb;background:#eff6ff;flex-shrink:0}.state-shell{min-height:180px;display:grid;place-items:center;align-content:center;gap:8px;padding:28px;text-align:center;border:1px solid #e2e8f0;border-radius:16px;background:#fff;color:#64748b}.state-shell strong{color:#0f172a}.state-shell.error{border-color:#fecaca;color:#b91c1c;background:#fff7f7}.state-action{margin-top:8px}.state-icon{color:#2563eb}.spin{animation:spin 1s linear infinite}.skeleton-stack{display:grid;gap:10px;padding:18px;border:1px solid #e2e8f0;border-radius:16px;background:#fff}.skeleton-line{height:18px;border-radius:999px;background:linear-gradient(90deg,#eef2f7,#f8fafc,#eef2f7);background-size:180% 100%;animation:shimmer 1.2s ease-in-out infinite}.skeleton-line:nth-child(2){width:72%}.skeleton-line:nth-child(3){width:54%}.lifecycle-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:16px}.lifecycle-step{min-height:44px;display:grid;place-items:center;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;background:#f8fafc;font-size:13px;font-weight:800}.lifecycle-step.active{color:#1d4ed8;border-color:#93c5fd;background:#eff6ff}.calculation-panel{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding:14px;border:1px solid #bfdbfe;border-radius:14px;color:#1e3a8a;background:#eff6ff}.calculation-panel strong,.calculation-panel span{display:block}.calculation-panel span{margin-top:3px;color:#475569;font-size:13px}.sticky-action-bar{position:sticky;bottom:14px;z-index:4;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;border:1px solid #dbeafe;border-radius:18px;background:#fffffff5;box-shadow:0 18px 44px #0f172a24;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.sticky-action-bar strong,.sticky-action-bar span{display:block}.sticky-action-bar span{margin-top:2px;color:#64748b;font-size:12px}.sticky-actions{display:flex;gap:8px}.drawer-backdrop{position:fixed;inset:0;z-index:30;display:flex;justify-content:flex-end;background:#0f172a6b;animation:fade-in .14s ease-out}.detail-drawer{position:relative;width:min(440px,100%);height:100%;overflow-y:auto;padding:28px;background:#fff;box-shadow:-16px 0 40px #0f172a2e;animation:slide-in-right .18s ease-out}.drawer-close{position:absolute;top:18px;right:18px;min-width:42px;min-height:42px}.detail-header{padding-right:44px}.detail-drawer h2{margin:14px 0 16px;color:#0f172a;line-height:1.22;overflow-wrap:anywhere}.detail-kpi{padding:18px;border-radius:16px;background:#eff6ff}.detail-kpi span,.detail-kpi strong{display:block}.detail-kpi span{color:#64748b;font-size:13px}.detail-kpi strong{margin-top:6px;color:#1d4ed8;font-size:38px}.detail-section{margin:16px 0;padding:16px;border:1px solid #e2e8f0;border-radius:14px;background:var(--panel-soft)}.detail-section p{margin:8px 0 0;color:#64748b;line-height:1.55}.detail-grid{margin-top:16px}.login-shell{min-height:calc(100vh - 68px);display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:36px;padding:42px 0}.login-hero h1{margin:28px 0 14px;color:#0f172a;font-size:46px;line-height:1.18;letter-spacing:0}.login-hero p,.login-card p{color:#64748b;line-height:1.65}.login-brand .brand-mark{flex:0 0 auto}.login-feature-list{display:grid;gap:14px;margin-top:28px;max-width:420px}.feature-card{padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--panel);box-shadow:var(--shadow)}.feature-card strong,.feature-card span{display:block}.feature-card span{margin-top:6px;color:#64748b;font-size:13px}.login-card{padding:38px;border:1px solid var(--line);border-radius:18px;background:var(--panel);box-shadow:var(--shadow-hover);text-align:center}.login-card>strong{display:block;margin-bottom:24px;color:#0f172a;font-size:22px}.info-row.subtle{margin-top:10px;background:#f8fafc}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{to{background-position:-180% 0}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in-right{0%{transform:translate(24px);opacity:.84}to{transform:translate(0);opacity:1}}@keyframes sheet-up{0%{transform:translateY(22px);opacity:.9}to{transform:translateY(0);opacity:1}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;z-index:20;width:min(84vw,300px);transform:translate(-105%);transition:transform .18s ease;box-shadow:14px 0 32px #0f172a24}.sidebar.open{transform:translate(0)}.sidebar-backdrop{position:fixed;inset:0;z-index:15;min-height:100vh;border:0;background:#0f172a38}.mobile-only{display:inline-flex}.content-area{padding:20px 16px 32px}.topbar-section{align-items:flex-start;flex-direction:column}.topbar-status{width:100%;flex-wrap:wrap;white-space:normal}.top-header{height:62px;padding:0 14px;gap:8px;overflow:hidden}.header-title{width:calc(100vw - 126px);flex:0 1 auto}.header-title strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-header span{display:none}.header-actions{gap:6px}.alerts-button,.session-pill{display:none}.session-action{min-height:38px;width:42px;padding:0;max-width:42px;font-size:13px;overflow:hidden;text-overflow:ellipsis}.session-action{font-size:0}.session-action svg{flex:0 0 auto}.metric-grid,.metric-grid.compact,.grid2,.grid3,.grid4,.placeholder-grid,.preset-grid,.two-column-grid,.builder,.strategy-builder-grid,.action-row{grid-template-columns:1fr}.action-row{grid-column:auto}.filters{align-items:stretch;flex-direction:column}.select{width:100%}.login-shell{grid-template-columns:1fr;gap:20px;padding:24px 0}.login-hero h1{font-size:32px;line-height:1.2}.login-card{padding:24px}.section-card-header,.result-card,.sticky-action-bar{flex-direction:column;align-items:stretch}.lifecycle-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.sticky-actions{display:grid;grid-template-columns:1fr 1fr}.sticky-actions .primary-button{grid-column:1 / -1}.page-heading h1,.hero-panel h1{font-size:25px;line-height:1.2}.page-heading.compact h1{font-size:22px}.page-heading p,.hero-panel p,.section-card-header p{font-size:14px;line-height:1.5}.hero-panel,.section-card{padding:18px;border-radius:14px}.primary-button,.secondary-button{width:100%}.search-result-button{align-items:flex-start;flex-direction:column}.detail-drawer{align-self:flex-end;width:100%;height:min(88vh,720px);border-radius:22px 22px 0 0;padding:22px 16px 24px;animation:sheet-up .18s ease-out}.detail-kpi strong{font-size:32px}}
