:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}html,body,#root{width:100%;height:100%;overflow:hidden}.stickman-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.role-card{position:absolute;background:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid;border-radius:6px;padding:8px 12px;min-width:120px;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:8px;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;z-index:10}.role-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.role-card.dragging{z-index:1000;transform:scale(1.05) rotate(2deg);box-shadow:0 8px 25px #0000004d;transition:none}.role-card.selected{z-index:100}.role-card-color-indicator{width:4px;height:24px;border-radius:2px;flex-shrink:0}.role-card-content{flex:1;display:flex;align-items:center;min-width:0}.role-card-text{color:#1e293b;font-size:14px;font-weight:500;white-space:pre-line;word-wrap:break-word;pointer-events:none;line-height:1.3;max-width:120px}.role-card-input{background:#fff;border:1px solid #CBD5E1;color:#1e293b;padding:4px 8px;border-radius:6px;font-size:14px;font-weight:500;width:100%;outline:none;cursor:text!important;resize:vertical;min-height:24px;max-height:120px;line-height:1.3;font-family:inherit}.role-card-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf633}.role-card-actions-left{display:flex;gap:4px;opacity:0;transition:opacity .2s;min-width:28px;justify-content:center}.role-card-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.role-card:hover .role-card-actions,.role-card:hover .role-card-actions-left{opacity:1}.role-card-action{background:#e2e8f080;border:none;border-radius:6px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#475569;transition:all .2s}.role-card-action:hover{background:#e2e8f0cc;color:#1e293b;transform:scale(1.1)}.role-card-action.save{background:#22c55e1a;border:1px solid #22C55E}.role-card-action.save:hover{background:#22c55e33;transform:scale(1.1)}.role-card-action.delete:hover{background:#ef4444cc;color:#fff}@media (max-width: 768px){.role-card-actions{opacity:1}.role-card{padding:10px 14px;min-width:100px}.role-card-action{width:28px;height:28px}}.floating-action-button{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);cursor:pointer;z-index:100;transition:all .2s ease}.floating-action-button:hover{background:var(--primary-dark);transform:scale(1.05) translateY(-2px);box-shadow:0 8px 25px #01918c4d}.floating-action-button:active{transform:scale(.95);box-shadow:var(--shadow)}@media (max-width: 768px){.floating-action-button{bottom:16px;right:16px;width:52px;height:52px}}.color-picker{position:fixed;bottom:80px;left:24px;background:#1e293bfa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:20px;box-shadow:0 20px 40px #0000004d;z-index:200;width:280px;cursor:default}.color-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.color-picker-title-section{display:flex;align-items:center;gap:8px}.color-picker-drag-handle{cursor:grab;color:#94a3b8;padding:6px;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;touch-action:none}.color-picker-drag-handle:hover{background:#47556980;color:#f1f5f9}.color-picker-drag-handle:active{cursor:grabbing;background:#475569cc}.color-picker-header h3{color:#f1f5f9;font-size:16px;font-weight:600;margin:0}.color-picker-close{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.color-picker-close:hover{background:#47556980;color:#f1f5f9}.color-picker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:16px}.color-option{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;position:relative;transition:all .2s}.color-option.selected{border-color:#fff;box-shadow:0 0 0 3px #fff3}.color-selected-indicator{color:#fff;font-size:16px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-shadow:0 1px 2px rgba(0,0,0,.5)}.color-picker-custom{display:flex;align-items:center;gap:12px;padding-top:12px;border-top:1px solid rgba(71,85,105,.5)}.color-picker-custom label{color:#94a3b8;font-size:14px;font-weight:500}.custom-color-input{width:50px;height:36px;border:2px solid rgba(71,85,105,.5);border-radius:8px;background:transparent;cursor:pointer;transition:border-color .2s}.custom-color-input:hover{border-color:#8b5cf6}@media (max-width: 768px){.color-picker{bottom:70px;left:16px;right:16px;width:auto}}.bottom-sheet-overlay{position:fixed;inset:0;background:#0006;z-index:300}.bottom-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--surface);border-radius:24px 24px 0 0;border-top:1px solid var(--surface-border);padding:8px 24px 24px;max-height:50vh;overflow-y:auto;box-shadow:0 -4px 20px #0000001a}.bottom-sheet-handle{width:48px;height:4px;background:var(--surface-border);border-radius:2px;margin:8px auto 16px}.bottom-sheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.bottom-sheet-header h3{color:var(--text);font-size:18px;font-weight:600;margin:0}.bottom-sheet-content{display:flex;flex-direction:column;gap:20px}.bottom-sheet-field{display:flex;flex-direction:column;gap:8px}.bottom-sheet-field label{color:var(--text-secondary);font-size:14px;font-weight:500}.bottom-sheet-edit-container{display:flex;gap:8px}.bottom-sheet-input{flex:1;background:var(--surface-light);border:1px solid var(--surface-border);color:var(--text);padding:10px 12px;border-radius:var(--radius);font-size:16px;outline:none;transition:all .2s}.bottom-sheet-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #01918c1a}.bottom-sheet-save-btn{background:var(--primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:all .2s}.bottom-sheet-save-btn:hover{background:var(--primary-dark)}.bottom-sheet-text-container{display:flex;align-items:center;justify-content:space-between;background:var(--surface-light);padding:10px 12px;border-radius:var(--radius);border:1px solid var(--surface-border)}.bottom-sheet-text{color:var(--text);font-size:16px}.bottom-sheet-edit-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s}.bottom-sheet-edit-btn:hover{background:var(--surface-border);color:var(--text)}.bottom-sheet-actions{margin-top:12px;display:flex;gap:12px}.bottom-sheet-action-btn{flex:1;background:var(--surface-light);color:var(--text);border:1px solid var(--surface-border);padding:12px 20px;border-radius:var(--radius);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.bottom-sheet-action-btn:hover{background:var(--surface-border)}.bottom-sheet-action-btn.delete{background:#dc26261a;color:var(--danger);border-color:#dc262633}.bottom-sheet-action-btn.delete:hover{background:#dc262633}@media (max-width: 768px){.bottom-sheet{padding-bottom:env(safe-area-inset-bottom,24px)}}.header{position:fixed;top:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:2px solid var(--surface-border);z-index:50;padding:12px 24px;box-shadow:var(--shadow)}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:20px}.header-title{display:flex;flex-direction:column;gap:2px}.header-title h1{color:var(--text);font-size:32px;font-weight:700;margin:0}.header-subtitle{color:var(--text-secondary);font-size:12px;font-weight:500}.header-actions{display:flex;align-items:center;gap:12px}.header-filename{display:flex;align-items:center;gap:8px;background:var(--surface-light);padding:8px 12px;border-radius:var(--radius);border:2px solid var(--surface-border)}.header-filename svg{color:var(--text-secondary);flex-shrink:0}.filename-input{background:transparent;border:none;color:var(--text);font-size:14px;outline:none;width:120px;font-weight:500}.filename-input::placeholder{color:var(--text-light)}.save-button{background:var(--primary);color:#fff;border:none;padding:10px 18px;border-radius:var(--radius);display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}.save-button:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.save-button:active{transform:translateY(0)}@media (max-width: 768px){.header{padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top));border-bottom-width:2px}.header-content{flex-wrap:wrap}.header-title h1{font-size:18px}.filename-input{width:80px}.save-button{padding:8px 14px;font-size:13px}}.app-footer{position:fixed;bottom:0;left:0;right:0;background:#1e293bf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(71,85,105,.3);padding:8px 16px;z-index:5}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:8px}.footer-text{color:#94a3b8;font-size:11px;font-weight:500;text-align:center}.footer-logo{width:16px;height:16px;opacity:.8;transition:opacity .2s}.footer-logo:hover{opacity:1}@media (max-width: 768px){.footer-text{font-size:10px}.footer-logo{width:14px;height:14px}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #01918C;--primary-light: #02c7c0;--primary-dark: #017A75;--secondary: #E5E5E5;--background: #FFFFFF;--surface: #FFFFFF;--surface-light: #F8F9FA;--surface-border: #D1D5DB;--surface-hover: #F3F4F6;--text: #111827;--text-secondary: #4B5563;--text-light: #6B7280;--success: #01918C;--danger: #DC2626;--radius: 12px;--radius-sm: 8px;--shadow: 0 2px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--background);color:var(--text);overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none}.app{width:100vw;height:100vh;position:relative;overflow:hidden;background:#fff}.roles-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.roles-container>*{pointer-events:auto}.fab-container{position:fixed;bottom:24px;right:24px;z-index:100}.color-picker-fab{position:fixed;bottom:24px;left:24px;width:48px;height:48px;border-radius:50%;border:2px solid var(--surface-border);background:var(--surface);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);cursor:pointer;z-index:100;transition:all .2s ease}.color-picker-fab:hover{transform:scale(1.05);box-shadow:0 6px 20px #0003;background:var(--surface-hover)}.color-picker-fab:active{transform:scale(.95)}.save-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--primary);color:#fff;padding:16px 32px;border-radius:var(--radius);font-size:16px;font-weight:600;box-shadow:var(--shadow-lg);z-index:1000}@media (max-width: 768px){.fab-container{bottom:50px;right:16px}.color-picker-fab{bottom:50px;left:16px}}@media (min-width: 769px){.fab-container{bottom:60px;right:24px}.color-picker-fab{bottom:60px;left:24px}}@media (display-mode: standalone){.app{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}*{scroll-behavior:smooth}body{overscroll-behavior-y:contain}
