:root{--teal: #09c2bd;--teal-dark: #079a96;--pink: #ff4fa0;--pink-dark: #e23d89;--gray: #ababab;--ink: #0f1729;--ink-soft: #34405a;--bg: #f4f7fb;--card: #ffffff;--line: #e4e9f2;--ok: #16a766;--warn: #f0a500;--radius: 16px;--shadow: 0 6px 24px rgba(15, 23, 41, .08);--font: "Segoe UI", "Assistant", "Heebo", system-ui, -apple-system, Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:var(--teal-dark)}.app{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;background:var(--ink);color:#fff;box-shadow:var(--shadow);position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:18px}.brand .logo{width:38px;height:38px}.brand small{display:block;font-weight:500;font-size:12px;color:var(--gray)}.topbar .who{font-size:13px;color:#cdd5e4;display:flex;align-items:center;gap:12px}.linkbtn{background:none;border:none;color:#cdd5e4;cursor:pointer;font:inherit;text-decoration:underline}.container{width:min(1100px,92vw);margin:0 auto;padding:26px 0 60px;flex:1}.progress{display:flex;gap:8px;margin:6px 0 26px}.progress .seg{flex:1;height:8px;border-radius:99px;background:#e0e6f0;overflow:hidden}.progress .seg.done{background:var(--teal)}.progress .seg.active{background:linear-gradient(90deg,var(--teal),var(--pink))}.steps-label{font-size:13px;color:var(--ink-soft);margin-bottom:4px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}.card+.card{margin-top:18px}h1{font-size:26px;margin:0 0 6px}h2{font-size:20px;margin:0 0 4px}.sub{color:var(--ink-soft);margin:0 0 18px;font-size:15px;line-height:1.55}.muted{color:var(--gray)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}.check{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid var(--line);border-radius:14px;cursor:pointer;background:#fff;transition:all .12s ease;-webkit-user-select:none;user-select:none}.check:hover{border-color:var(--teal)}.check.on{border-color:var(--teal);background:#09c2bd12}.check .box{width:22px;height:22px;border-radius:7px;border:2px solid var(--gray);flex:none;display:grid;place-items:center;color:#fff;font-size:14px;transition:all .12s ease}.check.on .box{background:var(--teal);border-color:var(--teal)}.check .emoji{font-size:18px}input[type=text],input[type=email],textarea,select{width:100%;padding:12px 14px;border:2px solid var(--line);border-radius:12px;font:inherit;color:var(--ink);background:#fff;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--teal)}textarea{resize:vertical;min-height:120px;line-height:1.6}label.field{display:block;margin-bottom:14px}label.field span{display:block;font-weight:600;margin-bottom:6px;font-size:14px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;font:inherit;font-weight:700;padding:12px 22px;border-radius:12px;background:var(--teal);color:#fff;transition:all .12s ease}.btn:hover{background:var(--teal-dark)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.pink{background:var(--pink)}.btn.pink:hover{background:var(--pink-dark)}.btn.ghost{background:#eef2f8;color:var(--ink)}.btn.ghost:hover{background:#e2e8f2}.btn.sm{padding:8px 14px;font-size:13px;border-radius:10px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.footer-nav{display:flex;justify-content:space-between;margin-top:24px;gap:10px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:600}.chip.todo{background:#eef2f8;color:var(--ink-soft)}.chip.in_progress{background:#09c2bd26;color:var(--teal-dark)}.chip.waiting{background:#f0a50029;color:#9a6b00}.chip.done{background:#16a76629;color:#0c7a45}.item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#fff}.item+.item{margin-top:8px}.item .handle{cursor:grab;color:var(--gray);font-size:18px}.item input{border:none;padding:4px 0}.item input:focus{border-bottom:2px solid var(--teal)}.item .num{width:26px;height:26px;border-radius:8px;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:13px;flex:none}.iconbtn{background:none;border:none;cursor:pointer;color:var(--gray);font-size:16px;padding:4px 6px;border-radius:8px}.iconbtn:hover{color:var(--pink);background:#fbe9f2}.pipeline-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tab{padding:9px 16px;border-radius:99px;border:2px solid var(--line);background:#fff;cursor:pointer;font-weight:600;font-size:14px}.tab.on{border-color:var(--teal);background:#09c2bd14;color:var(--teal-dark)}.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 820px){.split,.grid{grid-template-columns:1fr}}.split .pane{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}.split .pane.ai{background:#0f1729;color:#e8edf6;border-color:#0f1729}.pane.ai h3{color:var(--teal);margin:0 0 10px;display:flex;align-items:center;gap:8px}.recipe{font-size:14px;line-height:1.5}.recipe .trigger{color:var(--teal);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(--teal);color:#04201f}.kind.Wait{background:var(--warn);color:#3a2a00}.kind.Condition{background:var(--pink);color:#3a0420}.kind.Trigger{background:#fff;color:var(--ink)}.recipe .en{color:#9fb0cc;font-size:12px;direction:ltr;text-align:right}.thinking{color:var(--gray);font-style:italic}.stage-block{border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:14px}.stage-block>.stage-head{font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px}.dev-client{margin-bottom:26px}.dev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.task-card{border:1px solid var(--line);border-radius:14px;padding:16px;background:#fff}.task-card .head{display:flex;justify-content:space-between;align-items:start;gap:8px;margin-bottom:10px}.task-card .path{font-size:12px;color:var(--gray)}.task-card .title{font-weight:700}.dev-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.impl-list{list-style:none;padding:0;margin:0;counter-reset:impl}.impl-card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:16px;margin-bottom:14px;position:relative}.impl-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.impl-no{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--teal),var(--pink));color:#fff;font-weight:800;display:grid;place-items:center;flex:none}.impl-card .path{font-size:12px;color:var(--gray)}.impl-card .title{font-weight:700;font-size:15px}.impl-recipe{background:#0f1729;border-radius:12px;padding:14px}@media (max-width: 600px){body{overflow-x:hidden}.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:16px;gap:9px}.brand .logo{width:32px;height:32px}.topbar .who{font-size:12px;gap:8px}h1{font-size:21px}h2{font-size:18px}.card{padding:18px;border-radius:14px}.btn{padding:13px 18px}.btn.sm,.tab{padding:10px 14px}.iconbtn{font-size:18px;padding:8px}input[type=text],input[type=email],textarea,select{padding:13px 14px;font-size:16px}.row>label.field{flex:1 1 100%}.footer-nav{flex-direction:column-reverse}.footer-nav .btn{width:100%}.msg{max-width:94%}.bubble{font-size:15px}.chat-head{padding:13px 14px;font-size:15px}.chat-scroll{padding:14px}.chat-input{padding:10px}.dev-grid{grid-template-columns:1fr}.impl-head{flex-wrap:wrap}.impl-head select{width:100%}.recipe .step{flex-wrap:wrap}}.center{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:min(420px,94vw);text-align:center}.auth-card .logo{width:64px;height:64px;margin:0 auto 14px}.code-input{letter-spacing:10px;text-align:center;font-size:28px;font-weight:700}.note{font-size:13px;color:var(--ink-soft);background:#eef2f8;padding:10px 14px;border-radius:10px;margin-top:14px}.error{color:var(--pink-dark);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(--ink);color:#fff;padding:10px 18px;border-radius:99px;font-size:14px;box-shadow:var(--shadow);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:1.1fr .9fr;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:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--pink));color:#fff;font-weight:800;flex:none}.hodaya-badge.sm{width:26px;height:26px;font-size:13px}.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:10px;padding:16px 18px;border-bottom:1px solid var(--line);font-weight:700}.chat-scroll{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;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:#fff;border:1px solid var(--line);border-bottom-right-radius:4px}.msg.user .bubble{background:var(--teal);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(--gray);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:14px;border-top:1px solid var(--line);background:#fff}.chat-input textarea{min-height:0}.spec-panel{height:calc(100dvh - 160px);overflow-y:auto}.spec-section{margin-top:18px}.spec-section-title{font-weight:700;font-size:14px;color:var(--ink-soft);margin-bottom:8px}.chips-wrap{display:flex;flex-wrap:wrap;gap:6px}.src-chip{display:inline-flex;align-items:center;gap:6px;background:#09c2bd1a;color:var(--teal-dark);padding:5px 10px;border-radius:99px;font-size:13px;font-weight:600}.src-chip .x{background:none;border:none;color:var(--teal-dark);cursor:pointer;font-size:16px;line-height:1;padding:0}.proc{border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:10px;background:#fff}.proc-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.proc-name{font-weight:700;border:none;border-bottom:2px solid transparent;padding:4px 2px}.proc-name:focus{border-bottom-color:var(--teal)}.stage-row{padding:8px;border-radius:10px;background:#f7f9fc;margin-bottom:6px}.stage-name{border:none;background:none;flex:1;padding:2px}.stage-name:focus{border-bottom:2px solid var(--teal)}.num.sm{width:22px;height:22px;font-size:12px}.stage-summary{margin-top:6px;font-size:13px;min-height:0;background:#fff}
