:root{--background: #f6f8fb;--card: #ffffff;--foreground: #0f172a;--muted: #f1f5f9;--muted-foreground: #64748b;--border: #e6eaf0;--input: #e2e8f0;--primary: #09c2bd;--primary-600: #07a8a3;--primary-foreground: #ffffff;--secondary: #f1f5f9;--secondary-foreground: #334155;--accent: #eef2f7;--ring: #09c2bd;--destructive: #e23d6d;--pink: #ff4fa0;--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .05);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 10px 28px rgba(15, 23, 42, .1);--font: "Assistant", "Heebo", "Segoe UI", system-ui, -apple-system, Arial, sans-serif;--mono: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);background:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.5}a{color:var(--primary-600)}:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.ico{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;vertical-align:-3px}.ico.sm{width:15px;height:15px}.app{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 22px;background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:17px;color:var(--foreground)}.brand .logo{width:34px;height:34px}.brand small{display:block;font-weight:500;font-size:12px;color:var(--muted-foreground)}.brand .bar{color:var(--muted-foreground);font-weight:400}.who{font-size:13px;color:var(--muted-foreground);display:flex;align-items:center;gap:14px}.linkbtn{background:none;border:none;color:var(--muted-foreground);cursor:pointer;font:inherit;display:inline-flex;align-items:center;gap:5px}.linkbtn:hover{color:var(--foreground)}.container{width:min(1180px,94vw);margin:0 auto;padding:26px 0 60px;flex:1}h1{font-size:28px;font-weight:800;margin:0 0 6px;letter-spacing:-.01em}h2{font-size:20px;font-weight:700;margin:0 0 4px}h3{font-size:17px;font-weight:700;margin:0}.sub{color:var(--muted-foreground);margin:0 0 18px;font-size:15px}.muted{color:var(--muted-foreground)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:24px}.card+.card{margin-top:16px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;cursor:pointer;font:inherit;font-weight:600;font-size:14px;padding:0 18px;height:42px;border-radius:var(--radius-sm);background:var(--primary);color:var(--primary-foreground);display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .12s,box-shadow .12s,opacity .12s}.btn:hover{background:var(--primary-600)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.pink{background:var(--pink)}.btn.pink:hover{background:#e23d89}.btn.ghost{background:transparent;color:var(--foreground);border-color:var(--border)}.btn.ghost:hover{background:var(--accent)}.btn.subtle{background:var(--muted);color:var(--foreground)}.btn.subtle:hover{background:var(--accent)}.btn.sm{height:34px;padding:0 12px;font-size:13px}.btn.icon{width:38px;padding:0}.btn.block{width:100%}input:not([type]),input[type=text],input[type=email],input[type=password],textarea,select{width:100%;height:42px;padding:0 13px;border:1px solid var(--input);border-radius:var(--radius-sm);font:inherit;font-size:15px;color:var(--foreground);background:var(--card);outline:none;transition:border-color .12s,box-shadow .12s}textarea{height:auto;min-height:90px;padding:11px 13px;line-height:1.6;resize:vertical}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #09c2bd26}input::placeholder,textarea::placeholder{color:#94a3b8}label.field{display:block;margin-bottom:14px;min-width:0}label.field>span{display:block;font-weight:600;margin-bottom:6px;font-size:13.5px}.field-hint{font-size:12px;color:var(--muted-foreground);margin-top:4px}.input-icon{position:relative}.input-icon .ico{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--muted-foreground);pointer-events:none}.input-icon input{padding-right:38px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.footer-nav{display:flex;justify-content:space-between;margin-top:24px;gap:10px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid transparent}.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor}.badge.blue{background:#eff6ff;color:#1d4ed8;border-color:#dbeafe}.badge.amber{background:#fffbeb;color:#b45309;border-color:#fde68a}.badge.purple{background:#faf5ff;color:#7e22ce;border-color:#f3e8ff}.badge.emerald{background:#ecfdf5;color:#047857;border-color:#d1fae5}.badge.gray{background:var(--muted);color:var(--secondary-foreground);border-color:var(--border)}.badge.teal{background:#e6fbfa;color:var(--primary-600);border-color:#c5f3f1}.badge.pink{background:#fdf2f8;color:#be185d;border-color:#fce7f3}.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.chip.todo{background:var(--muted);color:var(--secondary-foreground)}.chip.in_progress{background:#eff6ff;color:#1d4ed8}.chip.waiting{background:#fffbeb;color:#b45309}.chip.done{background:#ecfdf5;color:#047857}.progress{display:flex;gap:8px;margin:6px 0 24px}.progress .seg{flex:1;height:7px;border-radius:999px;background:var(--muted);overflow:hidden}.progress .seg.done{background:var(--primary)}.progress .seg.active{background:linear-gradient(90deg,var(--primary),var(--pink))}.steps-label{font-size:13px;color:var(--muted-foreground);margin-bottom:4px}.bar{width:100%;height:8px;border-radius:999px;background:var(--muted);overflow:hidden}.bar>span{display:block;height:100%;border-radius:999px;background:var(--primary);transition:width .5s ease}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}.check{display:flex;align-items:center;gap:11px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--card);transition:all .12s;-webkit-user-select:none;user-select:none}.check:hover{border-color:var(--primary);background:var(--accent)}.check.on{border-color:var(--primary);background:#e6fbfa}.check .box{width:20px;height:20px;border-radius:6px;border:1.5px solid #cbd5e1;flex:none;display:grid;place-items:center;color:#fff;font-size:13px}.check.on .box{background:var(--primary);border-color:var(--primary)}.check .emoji{font-size:17px}.item{display:flex;align-items:center;gap:11px;padding:11px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card)}.item+.item{margin-top:8px}.item input{border:none;height:auto;padding:4px 0;background:none}.item input:focus{box-shadow:none;border-bottom:2px solid var(--primary)}.item .num{width:26px;height:26px;border-radius:7px;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:13px;flex:none;font-weight:700}.iconbtn{background:none;border:none;cursor:pointer;color:var(--muted-foreground);padding:5px;border-radius:7px;display:inline-flex}.iconbtn:hover{color:var(--destructive);background:#fdecf1}.pipeline-tabs,.dev-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tab{padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);cursor:pointer;font-weight:600;font-size:13.5px;color:var(--secondary-foreground)}.tab:hover{background:var(--accent)}.tab.on{border-color:var(--primary);background:#e6fbfa;color:var(--primary-600)}.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 820px){.split,.grid{grid-template-columns:1fr}}.split .pane{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.split .pane.ai{background:#0f172a;color:#e8edf6;border-color:#0f172a}.pane.ai h3{color:var(--primary);margin:0 0 10px}.recipe{font-size:14px}.recipe .trigger{color:var(--primary);font-weight:700}.recipe .step{display:flex;gap:8px;padding:8px 0;border-bottom:1px dashed #2a3550}.recipe .step:last-child{border-bottom:none}.recipe .kind{flex:none;font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;height:fit-content}.kind.Action{background:var(--primary);color:#04201f}.kind.Wait{background:#f59e0b;color:#3a2a00}.kind.Condition{background:var(--pink);color:#3a0420}.kind.Trigger{background:#fff;color:#0f172a}.recipe .en{color:#9fb0cc;font-size:12px;direction:ltr;text-align:right}.thinking{color:var(--muted-foreground);font-style:italic}.center{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:min(420px,94vw);text-align:center}.auth-card .logo{width:60px;height:60px;margin:0 auto 14px}.code-input{letter-spacing:10px;text-align:center;font-size:26px;font-weight:700;height:56px}.note{font-size:13px;color:var(--secondary-foreground);background:var(--muted);padding:10px 14px;border-radius:var(--radius-sm);margin-top:14px}.error{color:var(--destructive);font-size:14px;margin-top:8px}.spinner{display:inline-block;width:16px;height:16px;border:3px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--foreground);color:#fff;padding:10px 18px;border-radius:999px;font-size:14px;box-shadow:var(--shadow-lg);z-index:50}.chat-layout{display:block}.chat-layout.tab-chat .pane-spec,.chat-layout.tab-spec .pane-chat{display:none}.mobile-tabs{display:flex;gap:8px;margin-bottom:14px}.mobile-tabs .tab{flex:1;text-align:center}.pane{min-width:0;width:100%}@media (min-width: 901px){.chat-layout{display:grid;grid-template-columns:1fr 2fr;gap:18px;align-items:start}.chat-layout.tab-chat .pane-spec,.chat-layout.tab-spec .pane-chat{display:block}.mobile-tabs{display:none}.chat-card{height:calc(100dvh - 150px)}.spec-panel{height:auto;max-height:calc(100dvh - 150px)}}.hodaya-badge{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:9px;overflow:hidden;background:transparent;flex:none;box-shadow:var(--shadow-sm)}.hodaya-badge.sm{width:28px;height:28px;border-radius:8px}.hb-logo{width:100%;height:100%;display:block}.chat-card{display:flex;flex-direction:column;height:calc(100dvh - 160px);min-height:0;padding:0;overflow:hidden}.chat-head{display:flex;align-items:center;gap:11px;padding:14px 16px;border-bottom:1px solid var(--border)}.chat-head .ttl{font-weight:700;font-size:15px}.chat-head .st{font-size:12px;color:var(--muted-foreground)}.chat-head .ml{margin-inline-start:auto}.chat-scroll{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px;background:#fbfcfe}.msg{display:flex;gap:8px;align-items:flex-end;max-width:88%}.msg.user{align-self:flex-start;flex-direction:row-reverse}.msg.assistant{align-self:flex-end}.bubble{padding:11px 15px;border-radius:16px;line-height:1.55;font-size:15px;white-space:pre-wrap;overflow-wrap:anywhere}.msg.assistant .bubble{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-bottom-right-radius:4px}.msg.user .bubble{background:var(--primary);color:#fff;border-bottom-left-radius:4px}.bubble.typing{display:flex;gap:4px}.bubble.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted-foreground);animation:blink 1.2s infinite both}.bubble.typing span:nth-child(2){animation-delay:.2s}.bubble.typing span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3}40%{opacity:1}}.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border);background:var(--card)}.chat-input textarea{min-height:0;height:46px;background:var(--muted);border-color:transparent}.chat-input textarea:focus{background:var(--card)}.chat-foot{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--muted-foreground);padding:0 0 10px}.spec-panel{overflow-y:auto;padding:0}.spec-progress{padding:16px 20px;border-bottom:1px solid var(--border)}.spec-progress .lbl{display:flex;justify-content:space-between;font-size:13px;color:var(--muted-foreground);margin-bottom:7px}.spec-body{padding:18px 20px}.section{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;background:var(--card)}.section-head{display:flex;align-items:center;gap:10px;padding:13px 16px;background:#f8fafc;border-bottom:1px solid var(--border);font-weight:700}.section-num{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;background:#e6fbfa;color:var(--primary-600);font-size:13px;font-weight:800;flex:none}.section-body{padding:16px}.spec-section-title{font-weight:700;font-size:13.5px;color:var(--secondary-foreground);margin-bottom:8px}.spec-section{margin-top:16px}.chips-wrap{display:flex;flex-wrap:wrap;gap:6px}.src-chip{display:inline-flex;align-items:center;gap:6px;background:#e6fbfa;color:var(--primary-600);padding:5px 10px;border-radius:999px;font-size:13px;font-weight:600}.src-chip .x{background:none;border:none;color:var(--primary-600);cursor:pointer;font-size:15px;line-height:1;padding:0}.proc{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-bottom:10px;background:var(--card)}.proc-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.proc-name{font-weight:700;border:none;background:none;padding:4px 2px;height:auto}.proc-name:focus{box-shadow:none;border-bottom:2px solid var(--primary)}.stage-row{padding:8px;border-radius:8px;background:#f8fafc;margin-bottom:6px}.stage-name{border:none;background:none;flex:1;padding:2px;height:auto}.stage-name:focus{box-shadow:none;border-bottom:2px solid var(--primary)}.num.sm{width:22px;height:22px;font-size:12px}.stage-summary{margin-top:6px;font-size:13px;min-height:0;background:var(--card)}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.proj-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .15s,transform .15s}.proj-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.proj-card .top{padding:18px 18px 12px}.proj-card .top .row1{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.proj-card h3{font-size:18px;font-weight:700}.proj-card .cat{font-size:12px;color:var(--muted-foreground);margin-top:3px}.proj-card .meta{display:grid;grid-template-columns:1fr 1fr;gap:12px;font-size:13px;margin-top:14px}.proj-card .meta .k{color:var(--muted-foreground);display:flex;align-items:center;gap:6px;font-size:12px}.proj-card .meta .v{font-weight:600;margin-top:2px}.proj-card .foot{margin-top:auto;padding:12px 18px;border-top:1px solid var(--border);background:#f8fafc;display:flex;justify-content:space-between;align-items:center}.proj-card .foot .upd{font-size:12px;color:var(--muted-foreground)}.proj-card .enter{background:none;border:none;color:var(--primary-600);font-weight:600;font-size:13.5px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:6px 8px;border-radius:7px}.proj-card .enter:hover{background:#e6fbfa}.detail{display:grid;grid-template-columns:230px 1fr;gap:20px;align-items:start}@media (max-width: 860px){.detail{grid-template-columns:1fr}}.side-nav{position:sticky;top:84px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);padding:8px;box-shadow:var(--shadow-sm)}.side-nav .back{width:100%;justify-content:flex-start;margin-bottom:6px}.side-nav .nav-btn{display:flex;align-items:center;gap:10px;width:100%;text-align:right;padding:10px 12px;border-radius:var(--radius-sm);border:none;background:none;cursor:pointer;font:inherit;font-size:14px;color:var(--muted-foreground)}.side-nav .nav-btn:hover{background:var(--accent);color:var(--foreground)}.side-nav .nav-btn.on{background:#e6fbfa;color:var(--primary-600);font-weight:600}@media (max-width: 860px){.side-nav{position:static;display:flex;gap:6px;overflow-x:auto}.side-nav .nav-btn{white-space:nowrap;width:auto}.side-nav .back{width:auto}}.timer{display:inline-flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--border);border-radius:999px;padding:6px 8px 6px 6px;box-shadow:var(--shadow-sm)}.timer .seg2{display:flex;flex-direction:column;align-items:center;padding:0 10px}.timer .seg2+.seg2{border-right:1px solid var(--border)}.timer .seg2 .k{font-size:10px;color:var(--muted-foreground);line-height:1;margin-bottom:3px}.timer .seg2 .v{font-family:var(--mono);font-size:14px;font-weight:700;line-height:1}.timer .seg2.cur .k,.timer .seg2.cur .v{color:var(--primary-600)}.timer .ctrl{display:flex;gap:2px}.timer .tbtn{width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;display:grid;place-items:center;background:none}.timer .tbtn.play{color:#059669}.timer .tbtn.play:hover{background:#ecfdf5}.timer .tbtn.stop{color:var(--destructive)}.timer .tbtn.stop:hover{background:#fdecf1}.timer .tbtn:disabled{opacity:.4;cursor:not-allowed}.timer .seg2 .k.rec{color:var(--destructive)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.stat-cell{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;background:#f8fafc;text-align:center}.stat-cell .stat-big{font-size:28px;font-weight:800;margin:8px 0 2px}.impl-list{list-style:none;padding:0;margin:0}.impl-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;margin-bottom:14px}.impl-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.impl-head select{width:auto;min-width:120px;flex:none}.impl-no{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--primary),var(--pink));color:#fff;font-weight:800;display:grid;place-items:center;flex:none}.impl-card .path{font-size:12px;color:var(--muted-foreground)}.impl-card .title{font-weight:700;font-size:15px}.impl-recipe{background:#0f172a;border-radius:var(--radius-sm);padding:14px}.topics{display:flex;flex-direction:column;gap:12px}.topic h4{margin:0 0 8px;font-size:13px;color:var(--secondary-foreground)}.tpl{border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:8px;background:#f8fafc}.tpl-head{font-size:13px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}.tpl-body{font-size:14px;white-space:pre-wrap;background:var(--card);border:1px dashed var(--border);border-radius:8px;padding:8px 10px}.tagrow{font-size:14px;padding:6px 0;border-bottom:1px dashed var(--border)}.tagrow:last-child{border-bottom:none}.lead-map{margin-bottom:16px}.lead-row{padding:10px 0;border-bottom:1px solid var(--border)}.lead-row:last-child{border-bottom:none}.lead-name{font-weight:700}.lead-fields{font-size:13px;color:var(--primary-600);margin-top:4px}.dev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.link-form{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) auto;gap:10px;align-items:end}.link-form .field,.link-form input,.link-form select{min-width:0}.link-form .btn{height:42px;padding:0 24px}@media (max-width: 720px){.link-form{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.link-form .btn{grid-column:1 / -1}}@media (max-width: 460px){.link-form{grid-template-columns:1fr}}.task-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;background:var(--card)}@media (max-width: 600px){.container{width:94vw;padding:14px 0 16px}.topbar{padding:11px 14px;padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right))}.brand{font-size:15px}.brand .logo{width:30px;height:30px}.who{font-size:12px;gap:9px}h1{font-size:22px}h2{font-size:18px}.card{padding:18px}input,textarea,select{font-size:16px}.row>label.field{flex:1 1 100%}.footer-nav{flex-direction:column-reverse}.footer-nav .btn{width:100%}.chat-card,.spec-panel{height:calc(100dvh - 160px)}.msg{max-width:94%}.detail{grid-template-columns:1fr}.impl-head{flex-wrap:wrap}.impl-head select{width:100%}.recipe .step{flex-wrap:wrap}}
