*{box-sizing:border-box}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app-header{position:static;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #00000026;flex-shrink:0}.header-content{display:flex;justify-content:space-between;align-items:center;height:100%;padding:0 20px;max-width:100%}.header-left{display:flex;align-items:center;gap:12px}.logo-container{display:flex;align-items:center;gap:8px}.logo-icon{width:28px;height:28px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.app-title{margin:0;font-size:20px;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.app-subtitle{font-size:13px;color:#ffffffe6;font-weight:400;opacity:.9}.header-right{display:flex;align-items:center;gap:12px}.user-menu{position:relative;display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:8px;transition:all .2s}.user-info:hover{background:#ffffff1a}.dropdown-arrow{font-size:10px;margin-left:4px;transition:transform .2s}.user-dropdown{position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;border:1px solid rgba(0,0,0,.1);z-index:1000;min-width:180px;overflow:hidden;margin-top:8px}.dropdown-item{width:100%;padding:12px 16px;border:none;background:#fff;color:#333;font-size:14px;text-align:left;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:8px}.dropdown-item:hover{background:#f8f9fa}.dropdown-item.logout{border-top:1px solid #eee;color:#dc3545}.dropdown-item.logout:hover{background:#fff5f5}.user-avatar{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.3)}.user-name{font-size:14px;font-weight:500;color:#fff}.login-btn,.logout-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.login-btn:hover,.logout-btn:hover{background:#ffffff4d;border-color:#ffffff80}.version-badge{background:#fff3;color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:500;border:1px solid rgba(255,255,255,.3)}.auto-save-status{font-size:12px;display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;transition:all .2s ease;font-weight:500;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff}.auto-save-status.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.auto-save-status.clickable:hover{opacity:.8;transform:scale(1.02);background:#fff3}.auto-save-status.saved{background:#28a7454d;border-color:#28a74580}.auto-save-status.saving{background:#007bff4d;border-color:#007bff80;animation:pulse 1.5s infinite}.auto-save-status.error{background:#dc35454d;border-color:#dc354580}.auto-save-status.unsaved{background:#fd7e144d;border-color:#fd7e1480}.auto-save-status.disabled{background:#6c757d4d;border-color:#6c757d80}@media (max-width: 768px){.app-header{height:45px}.logo-icon{width:24px;height:24px}.app-title{font-size:18px}.app-subtitle{display:none}.header-content{padding:0 16px}}.auth-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal{background:#fff;border-radius:12px;padding:0;width:90%;max-width:400px;box-shadow:0 20px 40px #0000004d;animation:authModalSlide .3s ease-out}@keyframes authModalSlide{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #f0f0f0;margin-bottom:16px}.auth-header h2{margin:0;font-size:24px;font-weight:700;color:#333}.auth-close{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:background-color .2s}.auth-close:hover{background:#f5f5f5}.auth-form{padding:0 24px}.auth-field{margin-bottom:20px}.auth-field label{display:block;margin-bottom:6px;font-weight:600;color:#333;font-size:14px}.auth-field input{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.auth-field input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.auth-error{background:#fff5f5;border:1px solid #fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.auth-submit{width:100%;background:#007bff;color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-bottom:20px}.auth-submit:hover:not(:disabled){background:#0056b3}.auth-submit:disabled{background:#ccc;cursor:not-allowed}.auth-switch{text-align:center;padding:0 24px 20px;border-bottom:1px solid #f0f0f0}.auth-switch-btn{background:none;border:none;color:#007bff;text-decoration:underline;cursor:pointer;font-size:14px;transition:color .2s}.auth-switch-btn:hover{color:#0056b3}.auth-social{padding:20px 24px 24px}.auth-divider{text-align:center;margin-bottom:20px;position:relative}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#ddd}.auth-divider span{background:#fff;padding:0 16px;color:#666;font-size:14px;position:relative}.auth-social-buttons{display:flex;flex-direction:column;gap:12px}.auth-social-btn{width:100%;padding:12px 16px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px;position:relative}.auth-social-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.auth-icon{width:20px;height:20px;flex-shrink:0}.auth-icon-wrapper{width:24px;height:24px;background:#fff;border-radius:4px;display:flex;align-items:center;justify-content:center;padding:2px;flex-shrink:0}.auth-social-btn.naver{background:#03c75a;color:#fff}.auth-social-btn.google{background:#fff;color:#3c4043;border:1px solid #dadce0}.auth-social-btn.google:hover{background:#f8f9fa;border-color:#d2d4d7}.auth-social-btn.kakao{background:#fee500;color:#3c1e1e}.auth-reason{padding:16px 24px;background:#f8f9fa;border-radius:8px;margin:0 24px 24px;border-left:4px solid #007bff}.auth-reason p{margin:0 0 8px;font-size:15px;font-weight:500;color:#333}.auth-reason-sub{font-size:13px!important;color:#666!important;font-weight:400!important;margin:0!important}.auth-later-btn{background:none;border:none;color:#6c757d;font-size:14px;cursor:pointer;padding:8px 16px;border-radius:6px;transition:all .2s;margin-left:12px}.auth-later-btn:hover{background:#f8f9fa;color:#495057}.auth-social-note{margin-top:16px;text-align:center}.auth-social-note p{margin:0;font-size:13px;color:#666}.main-dashboard{min-height:100vh;background:#f8f9fa;display:flex;flex-direction:column;padding-top:0}.loading-screen{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:#f8f9fa}.loading-content{text-align:center}.loading-spinner{font-size:48px;margin-bottom:16px;animation:spin 2s linear infinite}.loading-text{font-size:24px;color:#333;margin-bottom:8px}.loading-subtext{font-size:16px;color:#666}.dashboard-content{flex:1;padding:1rem;width:100%;background:#fff}.flows-container{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start;align-content:flex-start!important;justify-content:flex-start}.flow-card{background:#fff;border:2px solid #e9ecef;border-radius:8px;padding:1rem;cursor:pointer;transition:all .3s ease;height:160px;width:240px;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.flow-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000001a;border-color:#007bff}.sample-card{border:2px solid transparent;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:relative;overflow:hidden}.sample-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #667eea4d;border-color:transparent}.sample-card .flow-card-header{align-items:center}.sample-card .flow-card-header h3{color:#fff;font-weight:600}.sample-badge{background:#fff3;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-transform:uppercase;letter-spacing:.5px}.sample-description{color:#ffffffe6;font-size:.85rem;line-height:1.4;margin-bottom:.5rem}.sample-card .flow-card-preview{margin-top:auto}.sample-card .preview-text{color:#ffffffe6;font-weight:500}.sample-card .preview-icon{font-size:1.5rem}.add-card{border:2px dashed #007bff;background:#f8f9fa;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#007bff;transition:all .3s ease;height:160px}.add-card:hover{background:#e3f2fd;border-color:#0056b3;color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 20px #007bff26}.add-icon{font-size:2rem;margin-bottom:.25rem;font-weight:300}.add-text{font-size:.9rem;font-weight:500}.flow-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.flow-card-header h3{font-size:1rem;color:#333;margin:0;flex:1;margin-right:.5rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flow-card-actions{display:flex;gap:.25rem;align-items:center;flex-shrink:0}.rename-btn{background:#ffffffe6;border:1px solid #e9ecef;font-size:1rem;cursor:pointer;transition:all .2s ease;padding:0;border-radius:4px;box-shadow:0 1px 3px #0000001a;width:32px;height:32px;min-width:32px;min-height:32px;max-width:32px;max-height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-sizing:border-box;line-height:1;text-align:center}.delete-btn{background:#dc3545;color:#fff;border:1px solid #dc3545;font-size:1rem;cursor:pointer;transition:all .2s ease;padding:0;border-radius:4px;box-shadow:0 1px 3px #0000001a;width:32px;height:32px;min-width:32px;min-height:32px;max-width:32px;max-height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-sizing:border-box;line-height:1;text-align:center}.rename-btn:hover{background:#e3f2fd;border-color:#2196f3;transform:translateY(-1px);box-shadow:0 2px 6px #2196f333}.delete-btn:hover{background:#c82333;border-color:#c82333;transform:translateY(-1px);box-shadow:0 2px 6px #dc35454d}.flow-rename-input-wrapper{display:flex;align-items:center;gap:.5rem;flex:1;max-width:calc(100% - 1rem)}.flow-rename-input{flex:1;min-width:0;padding:.25rem .5rem;border:1px solid #007bff;border-radius:4px;font-size:1rem;font-weight:600;background:#fff;outline:none;max-width:150px}.save-rename-btn,.cancel-rename-btn{background:#fffffff2;border:1px solid;cursor:pointer;padding:.25rem .5rem;border-radius:4px;font-size:1rem;transition:all .2s ease;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.save-rename-btn{color:#28a745;border-color:#28a745}.save-rename-btn:hover{background:#d4edda;transform:translateY(-1px);box-shadow:0 2px 6px #28a74533}.cancel-rename-btn{color:#dc3545;border-color:#dc3545}.cancel-rename-btn:hover{background:#f8d7da;transform:translateY(-1px);box-shadow:0 2px 6px #dc354533}.flow-card-meta{margin-bottom:.25rem;flex:1}.flow-date{font-size:.75rem;color:#6c757d;margin-bottom:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flow-card-preview{display:flex;align-items:center;gap:.25rem;padding:.5rem;background:#f8f9fa;border-radius:4px;color:#666;margin-top:auto}.preview-icon{font-size:1rem}.preview-text{font-size:.75rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-subtext{font-size:.7rem;color:#6c757d;margin-top:.125rem}.flows-loading{text-align:center;color:#6c757d;font-size:1.1rem;padding:3rem;background:#fff;border-radius:12px;border:2px solid #e9ecef}@media (max-width: 768px){.dashboard-content{padding:1rem}.flows-container{justify-content:flex-start}.flow-card{width:200px;min-height:60px;padding:.75rem}.flow-card-header h3{font-size:.9rem}.add-icon{font-size:1.5rem}.add-text{font-size:.8rem}}@media (max-width: 480px){.dashboard-content{padding:.75rem}.flows-container{flex-direction:column;align-items:flex-start}.flow-card{width:100%;max-width:300px;padding:.75rem;min-height:60px}}.flow-card:focus{outline:2px solid #007bff;outline-offset:2px}.add-card:focus{outline:2px solid #007bff;outline-offset:2px}.delete-btn:focus{outline:2px solid #dc3545;outline-offset:2px}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.custom-node{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-user-select:none;user-select:none;cursor:pointer;border-radius:8px}.custom-node-content{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;text-align:center;pointer-events:none}.custom-node-emoji{margin-bottom:4px;line-height:1}.custom-node-label{font-weight:600;color:#333;line-height:1.2;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.resize-handles{position:absolute;inset:0;pointer-events:none;border-radius:inherit}.resize-handle{position:absolute;width:12px;height:12px;background:#007bff;border:2px solid #fff;border-radius:50%;pointer-events:all;cursor:pointer;z-index:1000;transition:all .2s ease;-webkit-user-select:none;user-select:none}.resize-handle:hover{background:#0056b3;transform:scale(1.2)}.resize-handle-nw{top:-6px;left:-6px;cursor:nw-resize}.resize-handle-ne{top:-6px;right:-6px;cursor:ne-resize}.resize-handle-sw{bottom:-6px;left:-6px;cursor:sw-resize}.resize-handle-se{bottom:-6px;right:-6px;cursor:se-resize}.custom-node .react-flow__handle{opacity:0;transition:opacity .2s ease;z-index:100!important;position:absolute!important;visibility:visible!important}.custom-node:hover .react-flow__handle,.custom-node.selected .react-flow__handle{opacity:1}.custom-node .react-flow__handle[data-handleid=top]{top:-6px;left:50%;transform:translate(-50%)}.custom-node .react-flow__handle[data-handleid=bottom]{bottom:-6px;left:50%;transform:translate(-50%)}.custom-node .react-flow__handle[data-handleid=left]{left:-6px;top:50%;transform:translateY(-50%)}.custom-node .react-flow__handle[data-handleid=right]{right:-6px;top:50%;transform:translateY(-50%)}:root{color-scheme:light only}html{color-scheme:light}body{background-color:#fff!important;color:#333!important}input,select,textarea{background-color:#fff!important;color:#333!important;border:1px solid #ced4da!important}#root{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.node-palette{background:#f8f9faf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-right:1px solid rgba(233,236,239,.8);padding:16px;overflow-y:auto;overflow-x:visible;position:absolute;left:0;top:0;bottom:0;z-index:100;box-sizing:border-box;transition:all .3s ease;box-shadow:2px 0 12px #0000001a}.node-palette.expanded{width:260px}.node-palette.collapsed{width:60px}.palette-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.node-palette h3{margin:0;color:#333;font-size:18px;font-weight:600}.node-palette.collapsed .palette-header h3{display:none}.sidebar-toggle-button{position:absolute;right:-15px;top:50%;transform:translateY(-50%);width:30px;height:50px;background:#007bff!important;color:#fff!important;border:none;border-radius:0 8px 8px 0;cursor:pointer;font-size:16px;display:flex!important;align-items:center;justify-content:center;transition:background-color .3s ease;z-index:9999!important;box-shadow:2px 0 8px #0000004d;visibility:visible!important;opacity:1!important}.sidebar-toggle-button:hover{background:#0056b3!important;transform:translateY(-50%) scale(1.1)}.palette-section{margin-bottom:24px}.palette-section h4{margin:0 0 12px;color:#666;font-size:14px;font-weight:500;padding-bottom:4px;border-bottom:1px solid #e9ecef}.palette-items{display:grid;grid-template-columns:1fr 1fr;gap:8px;justify-items:center}.palette-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:grab;transition:all .2s ease;-webkit-user-select:none;user-select:none;box-shadow:0 2px 4px #0000001a;position:relative;min-height:60px;width:100px}.palette-item.basic-shape{max-width:100px;justify-self:start}.shape-visual{display:flex;align-items:center;justify-content:center;margin-bottom:6px}.shape-label{font-size:11px;color:#666;font-weight:500;text-align:center;line-height:1.2}.palette-item:before,.palette-item:after{content:"";position:absolute;width:8px;height:8px;border-radius:50%;background:#007bff;border:2px solid #fff;opacity:0;transition:opacity .2s ease}.palette-item:before{top:-4px;left:50%;transform:translate(-50%)}.palette-item:after{bottom:-4px;right:-4px;background:#28a745}.palette-item:hover:before,.palette-item:hover:after{opacity:1}.palette-item:hover{border-color:#007bff;box-shadow:0 0 10px #007bff4d}.palette-item:active{cursor:grabbing;transform:scale(.95)}.palette-item.basic-shape{justify-content:center;font-weight:600;color:#333;grid-column:1 / -1;width:100%}.palette-item.emoji-node{gap:4px}.palette-item .emoji{font-size:24px;line-height:1;margin-bottom:2px}.palette-item .label{font-size:12px;color:#333;font-weight:600;text-align:center;word-break:break-word;line-height:1.2;max-width:84px}.palette-item.dragging{opacity:.5;transform:rotate(5deg)}.node-palette::-webkit-scrollbar{width:6px}.node-palette::-webkit-scrollbar-track{background:#f1f1f1}.node-palette::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.node-palette::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.collapsed-content{display:flex;flex-direction:column;gap:16px}.quick-section{display:flex;flex-direction:column;gap:6px;align-items:center}.section-divider{width:80%;height:1px;background:#dee2e6;margin:8px 0}.quick-title{font-size:10px;color:#666;font-weight:500;text-align:center;writing-mode:horizontal-tb;white-space:nowrap}.quick-button{width:36px;height:36px;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:grab;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:12px;-webkit-user-select:none;user-select:none;box-shadow:0 2px 4px #0000001a;position:relative}.quick-button:hover{border-color:#007bff;box-shadow:0 0 10px #007bff4d}.quick-button:active{cursor:grabbing;transform:scale(.95)}.quick-button.basic-shape{font-weight:600;color:#495057;font-size:12px}.quick-button.emoji-node{font-size:16px}.node-palette .react-flow__handle,.node-palette .react-flow__handle-top,.node-palette .react-flow__handle-right,.node-palette .react-flow__handle-bottom,.node-palette .react-flow__handle-left,.node-palette .react-flow__handle:hover,.node-palette .react-flow__handle-top:hover,.node-palette .react-flow__handle-right:hover,.node-palette .react-flow__handle-bottom:hover,.node-palette .react-flow__handle-left:hover,.node-palette .react-flow__handle-connecting,.node-palette .react-flow__handle-valid,.node-palette .react-flow__handle-invalid,.node-palette *[class*=react-flow__handle],.node-palette *[class*=handle],.node-palette *[data-handleid],.node-palette *[data-handlepos]{display:none!important;visibility:hidden!important;pointer-events:none!important;opacity:0!important;width:0!important;height:0!important;position:absolute!important;top:-9999px!important;left:-9999px!important}.node-palette:hover .react-flow__handle,.node-palette:hover *[class*=react-flow__handle],.node-palette:focus .react-flow__handle,.node-palette:focus *[class*=react-flow__handle],.node-palette:active .react-flow__handle,.node-palette:active *[class*=react-flow__handle]{display:none!important;visibility:hidden!important;pointer-events:none!important;opacity:0!important}.node-palette *[style*="border-radius: 50%"],.node-palette *[style*="border-radius:50%"],.node-palette .circular,.node-palette .dot,.node-palette .connection-point{display:none!important}.palette-item.emoji-node:before,.palette-item.emoji-node:after,.palette-item:before,.palette-item:after,.quick-button:before,.quick-button:after,.quick-button.emoji-node:before,.quick-button.emoji-node:after{display:none!important;content:none!important;visibility:hidden!important;opacity:0!important}.palette-item.node-type-source,.quick-button.node-type-source{background:linear-gradient(135deg,#e8f5e8,#f1f8f1);border:none}.palette-item.node-type-source:hover,.quick-button.node-type-source:hover{background:linear-gradient(135deg,#c8e6c9,#e8f5e8)}.palette-item.node-type-account,.quick-button.node-type-account{background:linear-gradient(135deg,#e3f2fd,#f0f7ff);border:none}.palette-item.node-type-account:hover,.quick-button.node-type-account:hover{background:linear-gradient(135deg,#bbdefb,#e3f2fd)}.palette-item.node-type-sink,.quick-button.node-type-sink{background:linear-gradient(135deg,#fce4ec,#fff0f5);border:none}.palette-item.node-type-sink:hover,.quick-button.node-type-sink:hover{background:linear-gradient(135deg,#f8bbd0,#fce4ec)}.palette-item.node-type-flow,.quick-button.node-type-flow{background:linear-gradient(135deg,#f3e5f5,#faf5fb);border:none}.palette-item.node-type-flow:hover,.quick-button.node-type-flow:hover{background:linear-gradient(135deg,#e1bee7,#f3e5f5)}@media (max-width: 768px){.node-palette{display:none}}.properties-panel{width:320px;background:#f8f9faf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid rgba(233,236,239,.8);padding:16px;overflow-y:auto;position:absolute;right:0;top:0;bottom:0;z-index:100;box-sizing:border-box;box-shadow:-2px 0 12px #0000001a;color:#333!important}.properties-panel h3{margin:0 0 20px;color:#333;font-size:18px;font-weight:600}.no-selection{color:#666;text-align:center;font-size:14px;line-height:1.5;margin-top:40px}.properties-section{margin-bottom:24px;padding:16px;background:#fff;border-radius:8px;border:1px solid #e9ecef}.properties-section h4{margin:0 0 16px;color:#333;font-size:16px;font-weight:600;padding-bottom:8px;border-bottom:1px solid #e9ecef}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:4px;color:#495057!important;font-size:14px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #dee2e6;border-radius:4px;font-size:14px;background:#fff;color:#333!important;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.form-group textarea{resize:vertical;min-height:60px}.color-input-group{display:flex;align-items:center;gap:8px}.color-input-group input[type=color]{width:40px;height:40px;padding:2px;border-radius:4px;cursor:pointer}.color-input-group .color-value{font-size:12px;color:#666;font-family:Courier New,monospace;background:#f8f9fa;padding:4px 8px;border-radius:4px;border:1px solid #e9ecef}.node-type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.toggle-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;border:2px solid #e9ecef;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;min-height:64px}.toggle-button:hover{border-color:#007bff;background:#f8f9fa;transform:translateY(-1px)}.toggle-button.active{border-color:#007bff;background:#e7f3ff;color:#0056b3;font-weight:600}.toggle-icon{font-size:18px;margin-bottom:4px;display:block}.toggle-label{font-size:12px;font-weight:500;text-align:center;line-height:1.2}.toggle-button.active .toggle-icon{transform:scale(1.1)}.toggle-button[title*=수입원].active{background:#e8f5e8;border-color:#4caf50;color:#2e7d32}.toggle-button[title*=계좌].active{background:#e3f2fd;border-color:#2196f3;color:#1565c0}.toggle-button[title*=지출처].active{background:#fce4ec;border-color:#e91e63;color:#c2185b}.toggle-button[title*=메모].active{background:#f3e5f5;border-color:#9c27b0;color:#7b1fa2}.properties-panel::-webkit-scrollbar{width:6px}.properties-panel::-webkit-scrollbar-track{background:#f1f1f1}.properties-panel::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.properties-panel::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 1200px){.properties-panel{width:280px}}@media (max-width: 768px){.properties-panel{position:fixed;width:100%;height:40vh;inset:auto 0 0;border-left:none;border-top:1px solid #e9ecef;z-index:101}}.name-with-emoji{display:flex;align-items:center;gap:8px;position:relative}.emoji-selector-inline{font-size:18px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid #007bff;border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.emoji-selector-inline:hover{transform:scale(1.05);box-shadow:0 2px 4px #007bff4d}.name-input-with-emoji{flex:1;padding:8px 12px;border:1px solid #dee2e6;border-radius:4px;font-size:14px;background:#fff;color:#333!important;transition:border-color .2s ease;box-sizing:border-box}.name-input-with-emoji:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.emoji-grid{max-height:400px;overflow-y:auto}.emoji-category{margin-bottom:12px}.emoji-category-title{font-size:11px;color:#666;font-weight:600;margin-bottom:6px;padding-bottom:2px;border-bottom:1px solid #e9ecef}.emoji-list{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.emoji-button{width:32px;height:32px;border:1px solid #dee2e6;background:#fff;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.emoji-button:hover{border-color:#007bff;background:#e7f3ff;transform:scale(1.1)}.emoji-button.selected{border-color:#007bff;background:#007bff;color:#fff;box-shadow:0 2px 4px #007bff4d}.emoji-grid::-webkit-scrollbar{width:4px}.emoji-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.emoji-grid::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.emoji-grid::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.emoji-picker-wrapper{position:fixed;z-index:10000;top:auto;right:340px;box-shadow:0 4px 12px #00000026;border-radius:8px;overflow:hidden;width:350px}.EmojiPickerReact{--epr-bg-color: #ffffff !important;--epr-category-label-bg-color: #f8f9fa !important;--epr-hover-bg-color: #e7f3ff !important;--epr-focus-bg-color: #007bff !important;--epr-search-input-bg-color: #ffffff !important;--epr-picker-border-radius: 8px !important;font-family:system-ui,-apple-system,sans-serif!important}.EmojiPickerReact .epr-search{background:#f8f9fa!important;padding:12px!important;display:flex!important;align-items:center!important;gap:12px!important}.EmojiPickerReact .epr-search-container{position:relative!important;flex:1!important}.EmojiPickerReact .epr-search-container input{background:#fff!important;border:1px solid #dee2e6!important;color:#333!important;border-radius:18px!important;padding:8px 16px!important;width:100%!important;font-size:14px!important;height:36px!important;box-sizing:border-box!important}.EmojiPickerReact .epr-search-container input:focus{border-color:#007bff!important;box-shadow:0 0 0 2px #007bff1a!important;outline:none!important}.EmojiPickerReact .epr-search-container input::placeholder{color:#6c757d!important;font-size:14px!important}.EmojiPickerReact .epr-icn-search{display:none!important}.EmojiPickerReact .epr-emoji-category-label{font-size:12px!important;font-weight:600!important;color:#495057!important;text-transform:none!important}.EmojiPickerReact button.epr-emoji{font-size:20px!important}.EmojiPickerReact button.epr-emoji:hover{background:#e7f3ff!important}.quick-emoji-section{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:12px}.quick-emoji-title{font-size:12px;font-weight:600;color:#495057;margin-bottom:8px;text-align:center}.quick-emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;max-height:100px;overflow-y:auto}.quick-emoji-button{width:32px;height:32px;border:1px solid #dee2e6;background:#fff;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.quick-emoji-button:hover{border-color:#007bff;background:#e7f3ff;transform:scale(1.05)}.quick-emoji-button.selected{border-color:#007bff;background:#007bff;color:#fff;box-shadow:0 2px 4px #007bff4d}.quick-emoji-grid::-webkit-scrollbar{width:4px}.quick-emoji-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.quick-emoji-grid::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.quick-emoji-grid::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.size-input-group{display:flex;gap:12px}.size-input-item{flex:1;display:flex;flex-direction:column;gap:4px}.size-input-item label{font-size:12px;font-weight:500;color:#666}.size-input-item input{padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:14px;text-align:center;background:#fff;transition:border-color .2s ease}.size-input-item input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.size-unit{font-size:11px;color:#666;text-align:center;margin-top:2px}.style-button-group{display:flex;border:1px solid #ddd;border-radius:6px;overflow:hidden;margin-bottom:12px;background:#fff}.style-button{flex:1;min-width:48px;height:40px;border:none;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#555;position:relative;padding:8px}.style-button:not(:last-child):after{content:"";position:absolute;right:0;top:6px;bottom:6px;width:1px;background:#ddd}.style-button:hover{background:#f8f9fa;color:#333}.style-button.active{background:#007bff;color:#fff!important}.style-button.active:not(:last-child):after{background:#0056b3}.style-button svg{pointer-events:none;width:32px;height:16px;flex-shrink:0}.style-button svg line,.style-button svg path{stroke:currentColor}.multi-node-info{background:#e3f2fd;border:1px solid #bbdefb;border-radius:4px;padding:8px 12px;font-size:12px;color:#1976d2;margin-top:8px;line-height:1.4;text-align:center}.toolbar{position:static;height:60px;background:#fff;border-bottom:1px solid #e9ecef;display:flex;align-items:center;padding:0 20px;gap:24px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.toolbar-section{display:flex;align-items:center;gap:8px}.toolbar-section.auto-save-status{margin-left:auto}.toolbar-section.sample-notice{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 16px;border-radius:20px;margin-right:auto;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #667eea4d;max-width:400px;min-height:36px;height:36px;flex-shrink:1;overflow:hidden;transition:all .3s ease}.sample-badge{background:#fff3;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);height:20px;display:flex;align-items:center;flex-shrink:0}.sample-text{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex-shrink:1}.button-group{display:flex;gap:4px;border:1px solid #dee2e6;border-radius:6px;overflow:hidden}.toolbar-button{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;background:#fff;color:#495057;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.toolbar-button:hover{background:#f8f9fa;color:#007bff}.toolbar-button:active{transform:translateY(1px)}.toolbar-button.primary{background:#007bff;color:#fff;font-weight:500}.toolbar-button.primary:hover{background:#0056b3;color:#fff}.toolbar-button.disabled,.toolbar-button:disabled{background:#f8f9fa!important;color:#adb5bd!important;cursor:not-allowed!important;opacity:.6}.toolbar-button.disabled:hover,.toolbar-button:disabled:hover{background:#f8f9fa!important;color:#adb5bd!important;transform:none!important}.toolbar-button.danger{color:#dc3545;border:1px solid #dc3545;border-radius:6px}.toolbar-button.danger:hover{background:#dc3545;color:#fff}.toolbar-button.migration{color:#17a2b8;background:#e9f7fd;border:1px solid #bee5eb}.toolbar-button.migration:hover{background:#17a2b8;color:#fff}.file-input-label{position:relative;cursor:pointer}.status-indicator{font-size:12px;display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;transition:all .2s ease;font-weight:500}.status-indicator.saved{color:#28a745;background:#28a7451a;border:1px solid rgba(40,167,69,.2)}.status-indicator.saving{color:#007bff;background:#007bff1a;border:1px solid rgba(0,123,255,.2);animation:pulse 1.5s infinite}.status-indicator.error{color:#dc3545;background:#dc35451a;border:1px solid rgba(220,53,69,.2)}.status-indicator.unsaved{color:#fd7e14;background:#fd7e141a;border:1px solid rgba(253,126,20,.2)}.status-indicator.unknown,.status-indicator.disabled{color:#6c757d;background:#6c757d1a;border:1px solid rgba(108,117,125,.2)}.status-indicator.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.status-indicator.clickable:hover{opacity:.8;transform:scale(1.02)}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.hamburger-button{border:1px solid #dee2e6!important;border-radius:6px!important;padding:10px!important;background:#fff!important;cursor:pointer;transition:all .2s ease}.hamburger-button:hover{background:#f8f9fa!important;border-color:#adb5bd!important}.hamburger-icon{display:flex;flex-direction:column;width:18px;height:14px;justify-content:space-between}.hamburger-icon span{display:block;height:2px;background:#495057;border-radius:1px;transition:all .3s ease}.hamburger-button:hover .hamburger-icon span{background:#007bff}.toolbar-section:not(:first-child):not(.auto-save-status):before{content:"";width:1px;height:24px;background:#dee2e6;margin-right:8px}@media (max-width: 1200px){.toolbar-section.sample-notice{max-width:350px}.sample-text{font-size:13px}}@media (max-width: 1000px){.toolbar-section.sample-notice{max-width:280px}.sample-text{font-size:12px}}@media (max-width: 900px){.toolbar{flex-wrap:wrap;height:auto;min-height:60px;padding:8px 16px;gap:16px}.toolbar-section.sample-notice{max-width:250px;gap:8px;padding:6px 12px}.sample-text{font-size:11px}.button-group{flex-wrap:wrap}.toolbar-button{font-size:12px;padding:6px 10px}}@media (max-width: 700px){.toolbar{gap:8px;padding:8px 12px;overflow:hidden}.toolbar-section.sample-notice{max-width:200px;padding:6px 10px}.toolbar-section.auto-save-status{display:none}.sample-text{font-size:10px}.toolbar-button{padding:8px;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;white-space:nowrap;overflow:hidden;position:relative}.toolbar-button *{display:none}.toolbar-button{text-indent:-9999px}.toolbar-button:before{position:absolute;font-size:16px;text-indent:0;left:50%;top:50%;transform:translate(-50%,-50%)}.toolbar-button[title*=축소]:before{content:"🔍-"}.toolbar-button[title*=확대]:before{content:"🔍+"}.toolbar-button[title*="기본 크기"]:before{content:"🎯"}.toolbar-button[title*=자금흐름]:before{content:"💰"}.toolbar-button[title*="실행 취소"]:before{content:"↩️"}.toolbar-button[title*="다시 실행"]:before{content:"↪️"}.toolbar-button[title*=저장]:before{content:"💾"}.toolbar-button[title*=불러오기]:before{content:"📂"}.toolbar-button[title*=내보내기]:before{content:"📤"}.file-input-label[title*=가져오기]:before{content:"📥"}.toolbar-button[title*=삭제]:before{content:"🗑️"}.hamburger-button:before{content:"☰"}.hamburger-button .hamburger-icon{display:none}}.dropdown-container{position:relative;display:inline-block}.dropdown-button{border:1px solid #dee2e6;border-radius:6px;padding:8px 12px}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:200px;background:#fff;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:99999!important;overflow:visible}.dropdown-menu.layout-dropdown{min-width:220px}.dropdown-item{display:flex;align-items:center;width:100%;padding:12px 16px;border:none;background:transparent;text-align:left;cursor:pointer;font-size:14px;transition:all .15s ease;border-bottom:1px solid #f1f3f4;gap:10px}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:#f8f9fa;transform:translate(2px)}.dropdown-item:active{background:#e9ecef}.dropdown-icon{font-size:16px;width:20px;display:flex;justify-content:center;flex-shrink:0}.dropdown-label{font-weight:500;color:#212529;flex:1}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-4px) scaleY(.95);transform-origin:top}to{opacity:1;transform:translateY(0) scaleY(1);transform-origin:top}}@keyframes nodeSlide{0%{transform:scale(.95);opacity:.8}to{transform:scale(1);opacity:1}}.dashboard{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e9ecef;box-shadow:0 -2px 8px #0000001a;z-index:1000;transition:all .3s ease}.dashboard.collapsed{height:40px}.dashboard.expanded{height:350px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:6px 16px;cursor:pointer;background:#f8f9fa;border-bottom:1px solid #e9ecef;-webkit-user-select:none;user-select:none;height:40px;box-sizing:border-box}.dashboard-header:hover{background:#e9ecef}.dashboard-header h3{margin:0 12px 0 0;font-size:14px;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.dashboard-title{transition:all .3s ease}.toggle-button{background:none;border:none;font-size:12px;color:#666;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background-color .2s ease;flex-shrink:0}.toggle-button:hover{background:#dee2e6}.dashboard-tabs{display:flex;background:#f8f9fa;border-bottom:1px solid #e9ecef}.tab-button{flex:1;padding:10px 12px;border:none;background:transparent;color:#666;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.tab-button:hover{background:#e9ecef;color:#333}.tab-button.active{background:#fff;color:#007bff;border-bottom-color:#007bff}.dashboard-content{padding:12px 16px;height:calc(100% - 80px);overflow-y:auto;display:flex;gap:20px}.dashboard-section{flex:1;min-width:200px}.dashboard-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#495057;padding-bottom:6px;border-bottom:1px solid #e9ecef}.stats-grid{display:flex;gap:16px;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;min-width:80px}.stat-label{font-size:12px;color:#666;margin-bottom:4px}.stat-value{font-size:16px;font-weight:600;color:#333}.financial-stats{grid-template-columns:repeat(3,1fr);gap:20px}.financial-stats .stat-item{flex-direction:column;align-items:stretch;padding:16px;border-radius:8px;border:2px solid transparent;position:relative}.financial-stats .stat-item.income{background:linear-gradient(135deg,#e8f5e8,#f0fff0);border-color:#28a745}.financial-stats .stat-item.expense{background:linear-gradient(135deg,#ffe6e6,#fff0f0);border-color:#dc3545}.financial-stats .stat-item.balance.positive{background:linear-gradient(135deg,#e7f3ff,#f0f8ff);border-color:#007bff}.financial-stats .stat-item.balance.negative{background:linear-gradient(135deg,#fff3e0,#fffaf0);border-color:#fd7e14}.financial-stats .stat-label{font-size:13px;font-weight:600;color:#666;margin-bottom:8px}.financial-stats .stat-value{font-size:20px;font-weight:700;margin-bottom:4px}.financial-stats .income .stat-value{color:#28a745}.financial-stats .expense .stat-value{color:#dc3545}.financial-stats .balance.positive .stat-value{color:#007bff}.financial-stats .balance.negative .stat-value{color:#fd7e14}.stat-count{font-size:11px;color:#888;font-weight:500}.stat-trend{position:absolute;top:12px;right:12px;font-size:18px}.basic-stats{grid-template-columns:repeat(3,1fr)}.basic-stats .stat-item{background:#f8f9fa;border:1px solid #e9ecef}.category-grid{display:flex;flex-wrap:wrap;gap:8px}.category-item{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:#e7f3ff;border:1px solid #b3d9ff;border-radius:20px;font-size:12px;min-width:100px}.category-name{color:#06c;font-weight:500}.category-count{color:#049;font-weight:600;margin-left:8px}.flow-list{display:flex;flex-direction:column;gap:6px}.flow-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:4px;font-size:13px}.flow-item.expense{background:#ffe6e6;border:1px solid #ffb3b3}.flow-item.income{background:#e6ffe6;border:1px solid #b3ffb3}.flow-label{color:#495057;flex:1;margin-right:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flow-amount{font-weight:600;white-space:nowrap}.flow-item.expense .flow-amount{color:#dc3545}.flow-item.income .flow-amount{color:#28a745}.table-section{flex:1;max-width:100%}.flow-table-container{overflow-x:auto;border:1px solid #e9ecef;border-radius:6px;background:#fff}.flow-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.flow-table th:nth-child(1),.flow-table td:nth-child(1){width:25%}.flow-table th:nth-child(2),.flow-table td:nth-child(2){width:25%}.flow-table th:nth-child(3),.flow-table td:nth-child(3){width:25%}.flow-table th:nth-child(4),.flow-table td:nth-child(4){width:25%}.flow-table th:nth-child(5),.flow-table td:nth-child(5){width:60px;min-width:60px}.flow-table th{background:#f8f9fa;padding:12px 8px;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #e9ecef;white-space:nowrap}.flow-table th:nth-child(3){text-align:right}.flow-table th:nth-child(4){text-align:center;padding-left:16px}.flow-table td{padding:10px 8px;border-bottom:1px solid #f1f3f4;vertical-align:middle}.flow-table tr:hover{background:#f8f9fa}.source-cell,.dest-cell{font-weight:500;color:#333;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.price-cell{font-weight:600;color:#007bff;text-align:right}.repeat-cell,.category-cell{text-align:center;padding-left:16px}.repeat-badge,.category-badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap}.repeat-badge{background:#e3f2fd;color:#1976d2;border:1px solid #bbdefb}.repeat-badge.daily{background:#fff3e0;color:#f57c00;border-color:#ffcc02}.repeat-badge.weekly{background:#f3e5f5;color:#7b1fa2;border-color:#ce93d8}.repeat-badge.yearly{background:#e8f5e8;color:#388e3c;border-color:#a5d6a7}.repeat-badge.once{background:#fafafa;color:#616161;border-color:#e0e0e0}.category-badge{background:#f0f8ff;color:#06c;border:1px solid #b3d9ff}.empty-row{text-align:center;color:#666;font-style:italic;padding:20px}.add-row{background:#f8f9fa!important;outline:2px dashed #007bff!important;outline-offset:-1px!important}.add-row td{padding:8px 4px!important;border:none!important}.node-select,.repeat-select{width:100%;padding:4px 6px;border:1px solid #ced4da;border-radius:4px;font-size:12px;background:#fff;color:#333}.node-select-container .node-select{margin-top:0}.amount-input{width:100%;padding:4px 6px;border:1px solid #ced4da;border-radius:4px;font-size:12px;text-align:right;color:#333}.action-buttons{display:flex;gap:4px;justify-content:center;align-items:center;height:100%}.save-btn,.cancel-btn{width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}.save-btn{background:#28a745;color:#fff}.save-btn:hover{background:#218838}.cancel-btn{background:#dc3545;color:#fff}.cancel-btn:hover{background:#c82333}.table-footer{padding:12px;background:#f8f9fa;border-top:1px solid #e9ecef;text-align:center}.add-row-button{padding:8px 16px;background:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.add-row-button:hover:not(:disabled){background:#0056b3}.add-row-button:disabled{background:#6c757d;cursor:not-allowed}.dashboard-content::-webkit-scrollbar{height:6px}.dashboard-content::-webkit-scrollbar-track{background:#f1f1f1}.dashboard-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.dashboard-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 1200px){.dashboard{left:0;right:0}}@media (max-width: 900px){.dashboard{left:0;right:0}.dashboard-content{flex-direction:column;gap:16px}.stats-grid,.category-grid{justify-content:center}}.node-input-container{position:relative;width:100%}.node-tabs{display:flex;margin-bottom:6px;border:1px solid #dee2e6;border-radius:4px;overflow:hidden;background:#fff}.node-tabs .tab-button{flex:1;padding:6px 8px;border:none;background:#f8f9fa;color:#666;font-size:10px;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:none;border-radius:0}.node-tabs .tab-button:hover{background:#e9ecef;color:#333}.node-tabs .tab-button.active{background:#007bff;color:#fff}.node-tabs .tab-button:first-child{border-right:1px solid #dee2e6}.node-tabs .tab-button.active:first-child{border-right-color:#007bff}.new-node-form{display:flex;flex-direction:column;gap:4px;padding:8px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;height:64px;box-sizing:border-box;justify-content:flex-start}.node-select-container{display:flex;flex-direction:column;justify-content:flex-start;height:64px;padding:8px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;box-sizing:border-box}.form-row{display:flex;gap:4px}.emoji-input{width:32px;padding:4px 2px;border:1px solid #ced4da;border-radius:4px;font-size:12px;text-align:center;background:#fff;color:#333}.emoji-select{width:40px;padding:4px 2px;border:1px solid #ced4da;border-radius:4px;font-size:12px;text-align:center;background:#fff;color:#333}.new-node-form .emoji-selector-inline{width:32px;height:27px;font-size:14px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #ced4da;border-radius:4px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.new-node-form .emoji-selector-inline:hover{border-color:#007bff;background:#e7f3ff}.label-input{flex:1;padding:4px 6px;border:1px solid #ced4da;border-radius:4px;font-size:12px;background:#fff;color:#333}.category-select,.type-select{flex:1;padding:4px 6px;border:1px solid #ced4da;border-radius:4px;font-size:11px;background:#fff;color:#333}.new-node-form select option{font-size:11px}.add-row .source-cell,.add-row .dest-cell{min-width:180px;max-width:200px}.node-toggle input[type=checkbox]{margin-right:4px;transform:scale(.8)}.amount-input-container{display:flex;flex-direction:column;gap:4px;justify-content:flex-start;align-items:flex-start;height:64px;padding:8px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;box-sizing:border-box;margin-top:28px}.repeat-container{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;height:64px;padding:8px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;box-sizing:border-box;margin-top:28px}.action-cell{text-align:center;width:60px;padding:8px 4px}.quick-amount-buttons{display:flex;gap:2px;justify-content:center}.quick-amount-btn{padding:2px 4px;border:1px solid #dee2e6;border-radius:3px;background:#fff;color:#007bff;font-size:9px;cursor:pointer;transition:all .15s ease;font-weight:500;min-width:28px}.quick-amount-btn:hover{background:#007bff;color:#fff;transform:translateY(-1px)}.quick-amount-btn:active{transform:translateY(0)}.flow-manager-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.flow-manager-modal{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:0 20px 40px #0000004d;animation:flowManagerSlide .3s ease-out}@keyframes flowManagerSlide{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.flow-manager-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #f0f0f0;margin-bottom:24px}.flow-manager-header h2{margin:0;font-size:24px;font-weight:700;color:#333}.flow-manager-close{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:background-color .2s}.flow-manager-close:hover{background:#f5f5f5}.flow-manager-content{padding:0 24px 24px;max-height:calc(80vh - 100px);overflow-y:auto}.flow-manager-section{margin-bottom:32px}.flow-manager-section h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#333}.create-flow-form{display:flex;gap:12px}.flow-title-input{flex:1;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s}.flow-title-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.create-flow-btn{background:#007bff;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;white-space:nowrap}.create-flow-btn:hover:not(:disabled){background:#0056b3}.create-flow-btn:disabled{background:#ccc;cursor:not-allowed}.flow-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.refresh-btn{background:#f8f9fa;border:1px solid #dee2e6;padding:8px 12px;border-radius:6px;cursor:pointer;transition:background-color .2s;font-size:14px}.refresh-btn:hover:not(:disabled){background:#e9ecef}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.flow-list{display:flex;flex-direction:column;gap:12px}.flow-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border:1px solid #e9ecef;border-radius:8px;transition:border-color .2s,box-shadow .2s}.flow-item:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff1a}.flow-item.active{border-color:#007bff;background:#f8f9ff}.flow-info{flex:1}.flow-title{margin:0 0 4px;font-size:16px;font-weight:600;color:#333}.flow-date{margin:0;font-size:14px;color:#666}.flow-actions{display:flex;gap:.25rem;align-items:center;flex-shrink:0}.flow-manager .load-btn,.flow-manager .delete-btn{background:#ffffffe6!important;border:1px solid #e9ecef!important;font-size:1rem!important;cursor:pointer!important;transition:all .2s ease!important;padding:0!important;border-radius:4px!important;box-shadow:0 1px 3px #0000001a!important;width:32px!important;height:32px!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;box-sizing:border-box!important;min-width:32px!important;max-width:32px!important}.flow-manager .load-btn:hover:not(:disabled){background:#e3f2fd!important;border-color:#2196f3!important;transform:translateY(-1px)!important;box-shadow:0 2px 6px #2196f333!important}.flow-manager .delete-btn:hover:not(:disabled){background:#ffebee!important;border-color:#f44336!important;transform:translateY(-1px)!important;box-shadow:0 2px 6px #f4433633!important}.flow-manager .load-btn:disabled,.flow-manager .delete-btn:disabled{opacity:.6;cursor:not-allowed}.current-flow-info{background:#f8f9fa;padding:16px;border-radius:8px;border:1px solid #dee2e6}.current-flow-info p{margin:0 0 8px;font-size:14px;color:#495057}.current-flow-info p:last-child{margin-bottom:0}.flow-manager-error{background:#fff5f5;border:1px solid #fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.flow-manager-loading{text-align:center;padding:32px;color:#666;font-size:16px}.flow-manager-empty{text-align:center;padding:32px;color:#999;font-style:italic}.flow-manager-message{text-align:center;padding:32px;color:#666;font-size:16px}.sample-flow{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.sample-flow:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px);transition:all .3s ease}.sample-flow .flow-title{color:#fff;font-size:18px}.sample-flow .flow-description{color:#ffffffe6;font-size:14px;margin:4px 0 0}.sample-flow .load-btn{background:#fff;color:#667eea;font-weight:600}.sample-flow .load-btn:hover{background:#f0f0f0}.migration-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.migration-modal{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:80vh;overflow:hidden;box-shadow:0 20px 40px #0000004d;animation:migrationSlide .3s ease-out}@keyframes migrationSlide{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.migration-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #f0f0f0;margin-bottom:24px}.migration-header h2{margin:0;font-size:24px;font-weight:700;color:#333}.migration-close{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:background-color .2s}.migration-close:hover{background:#f5f5f5}.migration-content{padding:0 24px 24px;max-height:calc(80vh - 100px);overflow-y:auto}.migration-info{margin-bottom:24px}.migration-info h3{margin:0 0 12px;font-size:18px;font-weight:600;color:#333}.migration-info p{margin:0;color:#666;line-height:1.5}.migration-status{background:#e3f2fd;border:1px solid #bbdefb;color:#1976d2;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.migration-status.success{background:#e8f5e8;border-color:#c8e6c9;color:#2e7d32}.migration-error{background:#fff5f5;border:1px solid #fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.migration-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.migrate-btn,.backup-btn{width:100%;padding:14px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.migrate-btn{background:#007bff;color:#fff}.migrate-btn:hover:not(:disabled){background:#0056b3}.backup-btn{background:#6c757d;color:#fff}.backup-btn:hover:not(:disabled){background:#545b62}.migrate-btn:disabled,.backup-btn:disabled{background:#ccc;cursor:not-allowed}.migration-warning{background:#fff8e1;border:1px solid #ffcc02;padding:16px;border-radius:8px}.migration-warning h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#e65100}.migration-warning ul{margin:0;padding-left:20px;color:#bf360c}.migration-warning li{margin-bottom:4px;font-size:14px;line-height:1.4}.migration-warning li:last-child{margin-bottom:0}.share-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.share-modal-content{background:#fff;border-radius:12px;max-width:800px;max-height:90vh;width:100%;overflow-y:auto;box-shadow:0 20px 40px #0000004d}.share-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #e9ecef}.share-modal-header h3{margin:0;font-size:18px;font-weight:600;color:#2c3e50}.share-modal-close{background:none;border:none;font-size:24px;color:#6c757d;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.share-modal-close:hover{background:#f8f9fa;color:#495057}.share-modal-body{padding:24px}.share-options{margin-bottom:20px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.share-option{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#495057;margin:0}.share-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#007bff}.share-option span{font-weight:500;-webkit-user-select:none;user-select:none}.share-modal-loading{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #e9ecef;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.share-image-container{margin-bottom:24px;text-align:center;border-radius:8px;overflow:hidden;border:1px solid #e9ecef;position:relative}.share-image{max-width:100%;height:auto;display:block;margin:0 auto}.image-regenerating-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.small-loading-spinner{width:24px;height:24px;border:3px solid #e9ecef;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.image-regenerating-overlay span{font-size:14px;color:#495057;font-weight:500}.share-modal-actions{display:flex;gap:12px;justify-content:center;margin-bottom:16px}.share-btn{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.download-btn{background:#007bff;color:#fff}.download-btn:hover{background:#0056b3;transform:translateY(-1px)}.copy-btn{background:#28a745;color:#fff}.copy-btn:hover{background:#1e7e34;transform:translateY(-1px)}.share-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.share-btn:disabled:hover{background:#6c757d!important;transform:none!important}.download-btn:disabled:hover{background:#6c757d!important}.copy-btn:disabled:hover{background:#6c757d!important}.share-help-text{text-align:center;color:#6c757d;font-size:14px;margin:0}.share-modal-error{text-align:center;padding:40px 20px;color:#dc3545}.share-modal-error .share-btn{background:#dc3545;color:#fff;margin-top:16px}.share-modal-error .share-btn:hover{background:#c82333}@media (max-width: 768px){.share-modal-overlay{padding:10px}.share-modal-content{max-height:95vh}.share-modal-header{padding:16px 20px 12px}.share-modal-body{padding:20px}.share-modal-actions{flex-direction:column}.share-btn{width:100%;justify-content:center}}.toast{position:fixed;bottom:60px;left:50%;transform:translate(-50%) translateY(100%);z-index:9999;min-width:200px;max-width:400px;padding:12px 16px;border-radius:8px;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;font-weight:500;box-shadow:0 4px 12px #00000026;transition:transform .3s ease-in-out;opacity:0}.toast-visible{transform:translate(-50%) translateY(0);opacity:1}.toast-success{background-color:#6b7280}.toast-info{background-color:#3b82f6}.toast-warning{background-color:#f59e0b}.toast-error{background-color:#ef4444}.toast-content{display:flex;align-items:center;justify-content:center;gap:8px}.toast-message{text-align:center}@media (max-width: 768px){.toast{bottom:20px;left:10px;right:10px;max-width:none;transform:translateY(100%)}.toast-visible{transform:translateY(0)}}.settings-page{width:100vw;height:100vh;display:flex;flex-direction:column;background:#f8f9fa}.settings-container{display:flex;flex:1;overflow:hidden}.settings-sidebar{width:240px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;padding:1rem 0}.settings-tab{padding:.75rem 1.5rem;border:none;background:none;text-align:left;font-size:.95rem;cursor:pointer;transition:all .2s ease;color:#495057;display:flex;align-items:center;gap:.5rem}.settings-tab:hover{background:#f8f9fa}.settings-tab.active{background:#e7f3ff;color:#007bff;font-weight:600;border-right:3px solid #007bff}.settings-tab.back-button{margin-top:auto;color:#6c757d;font-size:.9rem}.settings-tab.back-button:hover{color:#007bff}.settings-content{flex:1;overflow-y:auto;padding:2rem}.settings-section{max-width:800px;background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a}.settings-section h2{margin:0 0 1.5rem;font-size:1.5rem;color:#212529}.settings-section h3{margin:0 0 .5rem;font-size:1.1rem;color:#dc3545}.profile-info{display:flex;flex-direction:column;gap:1.5rem}.profile-image-large{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid #e0e0e0}.info-group{display:flex;flex-direction:column;gap:.5rem}.info-group label{font-weight:600;color:#495057;font-size:.9rem}.info-group .info-value{padding:.75rem;background:#f8f9fa;border-radius:4px;color:#212529}.info-section{display:flex;flex-direction:column;gap:1.5rem}.contact-link{color:#007bff;text-decoration:none}.contact-link:hover{text-decoration:underline}.danger-zone{margin-top:3rem;padding:1.5rem;background:#fff5f5;border:1px solid #ffdddd;border-radius:8px}.danger-zone p{margin:.5rem 0 1rem;color:#721c24;font-size:.9rem}.delete-account-btn{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.delete-account-btn:hover{background:#c82333}.changelog{display:flex;flex-direction:column;gap:2rem}.changelog-item{border-left:3px solid #007bff;padding-left:1.5rem}.changelog-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.changelog-header h3{margin:0;font-size:1.25rem;color:#007bff}.changelog-date{font-size:.85rem;color:#6c757d}.changelog-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.changelog-section{margin-bottom:1rem}.changelog-section-title{margin:0 0 .5rem;font-size:.95rem;font-weight:600;color:#495057}.changelog-list li{padding:.25rem 0;color:#495057;font-size:.9rem;line-height:1.5}.show-more-btn{padding:.75rem 1.5rem;background:#fff;border:2px solid #007bff;color:#007bff;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.show-more-btn:hover{background:#007bff;color:#fff;transform:translateY(-1px);box-shadow:0 4px 8px #007bff33}@media (max-width: 768px){.settings-container{flex-direction:column}.settings-sidebar{width:100%;flex-direction:row;border-right:none;border-bottom:1px solid #e0e0e0;overflow-x:auto;padding:.5rem}.settings-tab{padding:.5rem 1rem;white-space:nowrap}.settings-tab.active{border-right:none;border-bottom:3px solid #007bff}.settings-tab.back-button{margin-top:0}.settings-content,.settings-section{padding:1rem}}
