:root{font-family:Inter,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;--ribbon-height: 40px}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;width:100vw;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}}#root{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}.app-container{width:100%;height:100%;position:relative}.scene-wrapper{position:absolute;top:var(--ribbon-height, 40px);left:0;right:0;bottom:0;width:100%;height:calc(100% - var(--ribbon-height, 40px))}.button-group{position:absolute;top:20px;left:20px;z-index:100;display:flex;gap:10px}.grid-button,.lines-button{padding:10px 20px;background:#4a9eff;color:#fff;border:none;border-radius:5px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #00000026;transition:all .2s}.grid-button:hover,.lines-button:hover{background:#3a8eef;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.lines-button{background:#00f}.lines-button:hover{background:#00c}.login-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#7e22ce);display:flex;justify-content:center;align-items:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.login-box{background:#fffffff2;border-radius:16px;padding:40px;width:420px;box-shadow:0 20px 60px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:32px}.login-header h1{margin:0 0 8px;color:#1e3c72;font-size:32px;font-weight:700}.login-header p{margin:0;color:#666;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:8px}.login-field label{color:#333;font-size:14px;font-weight:600}.login-field input{padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:15px;transition:all .2s;outline:none}.login-field input:focus{border-color:#2a5298;box-shadow:0 0 0 3px #2a52981a}.login-field input:disabled{background:#f5f5f5;cursor:not-allowed}.login-error{padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;text-align:center}.login-btn{padding:14px;background:linear-gradient(135deg,#2a5298,#1e3c72);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#3462b8,#2a4c92);transform:translateY(-2px);box-shadow:0 8px 20px #2a529866}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center;color:#999;font-size:12px}.login-footer p{margin:0}.about-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:5000}.about-modal{background:#fff;border-radius:8px;width:640px;max-width:calc(100% - 40px);box-shadow:0 20px 60px #00000059;overflow:hidden}.about-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #eee}.about-header h2{margin:0;font-size:18px}.about-close{background:transparent;border:none;font-size:22px;line-height:1;cursor:pointer}.about-body{padding:18px 20px;color:#333;line-height:1.6}.about-body p{margin:0 0 12px}.about-footer{padding:12px 20px;border-top:1px solid #eee;text-align:right}.about-ok{background:#2d7ef7;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer}.ribbon-menu{position:fixed;top:0;left:0;right:0;z-index:2000;background:linear-gradient(to bottom,#2d2d2d,#252525);box-shadow:0 2px 8px #0000004d;-webkit-user-select:none;user-select:none}.ribbon-menu.collapsed .ribbon-content{max-height:0;min-height:0;opacity:0;overflow:hidden;padding:0;margin:0;border:none}.ribbon-tabs{display:flex;background:#1e1e1e;border-bottom:1px solid #3a3a3a;padding:0 10px;position:relative}.ribbon-tab{padding:8px 20px;color:#ccc;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;border-bottom:2px solid transparent}.ribbon-tab:hover{background:#ffffff0d;color:#fff}.ribbon-tab.active{color:#fff;background:#2d2d2d;border-bottom-color:#4285f4}.ribbon-content{padding:6px 10px;min-height:60px;max-height:200px;opacity:1;overflow:hidden}.ribbon-panel{display:flex;align-items:flex-start;gap:4px}.ribbon-group{display:flex;flex-direction:column;padding:4px 8px}.ribbon-group-title{display:none}.ribbon-separator{width:1px;background:#3a3a3a;margin:0 8px;align-self:stretch}.ribbon-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 10px;background:transparent;border:1px solid transparent;border-radius:4px;color:#ccc;font-size:10px;cursor:pointer;transition:all .2s;min-width:55px}.ribbon-btn:hover{background:#ffffff14;border-color:#ffffff1a;color:#fff}.ribbon-btn:active{background:#ffffff1f;transform:translateY(1px)}.ribbon-btn.active{background:#4285f44d;border-color:#4285f480;color:#fff}.ribbon-icon{font-size:20px;filter:grayscale(.3)}.ribbon-btn:hover .ribbon-icon{filter:grayscale(0)}.ribbon-collapse-btn{margin-left:auto;background:transparent;border:none;color:#999;font-size:12px;padding:8px 16px;cursor:pointer;transition:all .2s;align-self:center}.ribbon-collapse-btn:hover{color:#fff;background:#ffffff0d}.ribbon-group{display:flex;flex-direction:row;flex-wrap:wrap;gap:4px;align-items:center}.ribbon-group .ribbon-group-title{width:100%;flex-basis:100%}@media(max-width:768px){.ribbon-tabs{overflow-x:auto;scrollbar-width:thin}.ribbon-tab{padding:6px 12px;font-size:12px}.ribbon-content{padding:6px;min-height:60px}.ribbon-btn{min-width:50px;padding:6px 8px;font-size:10px}.ribbon-icon{font-size:16px}}.project-selector-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298,#7e22ce);display:flex;justify-content:center;align-items:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;overflow-y:auto;padding:20px}.project-selector-box{background:#fffffff2;border-radius:16px;padding:40px;width:100%;max-width:900px;box-shadow:0 20px 60px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.project-selector-header{text-align:center;margin-bottom:32px;position:relative}.project-selector-header h1{margin:0 0 8px;color:#1e3c72;font-size:32px;font-weight:700}.project-selector-header p{margin:0;color:#666;font-size:16px}.project-selector-content{display:flex;flex-direction:column;gap:32px}.projects-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.project-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative}.project-card:hover{border-color:#2a5298;transform:translateY(-4px);box-shadow:0 8px 24px #2a529833}.project-card-icon{font-size:36px;margin-bottom:8px}.project-card-title{font-size:15px;font-weight:600;color:#1e3c72;margin-bottom:6px;word-break:break-word}.project-card-description{font-size:12px;color:#666;margin-bottom:8px;min-height:32px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-date{font-size:11px;color:#999;margin-top:auto}.project-delete-btn{position:absolute;top:6px;right:6px;background:#f44336e6;border:none;border-radius:4px;padding:4px 8px;font-size:14px;cursor:pointer;opacity:0;transition:opacity .2s}.project-card:hover .project-delete-btn{opacity:1}.project-delete-btn:hover{background:#d32f2f}.new-project-card{border:2px dashed #2a5298;background:linear-gradient(135deg,#2a52980d,#7e22ce0d)}.new-project-card:hover{border-color:#1e3c72;background:linear-gradient(135deg,#2a52981a,#7e22ce1a)}.new-project-form{background:#fff;border:2px solid #2a5298;border-radius:12px;padding:20px}.new-project-form h3{margin:0 0 16px;color:#1e3c72;font-size:18px}.form-field{margin-bottom:16px}.form-field label{display:block;margin-bottom:6px;color:#333;font-size:14px;font-weight:600}.form-field input,.form-field textarea{width:100%;padding:10px 14px;border:2px solid #ddd;border-radius:8px;font-size:15px;font-family:inherit;transition:all .2s;outline:none}.form-field input:focus,.form-field textarea:focus{border-color:#2a5298;box-shadow:0 0 0 3px #2a52981a}.form-field textarea{resize:vertical}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.btn-cancel,.btn-create{padding:10px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{background:#e0e0e0;color:#666}.btn-cancel:hover{background:#d0d0d0}.btn-create{background:linear-gradient(135deg,#2a5298,#1e3c72);color:#fff}.btn-create:hover{background:linear-gradient(135deg,#3462b8,#2a4c92);transform:translateY(-2px);box-shadow:0 8px 20px #2a529866}.projects-list h3{margin:0 0 16px;color:#1e3c72;font-size:20px}
