body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1 1;position:relative}.main-content{display:flex;height:100%}.area-container,.content-area{display:flex;flex:1 1;overflow:hidden;position:relative}.geometry-area,.graph-area{flex:1 1;height:100%;position:relative}.content-area .toolbar{background:#fff;bottom:0;box-shadow:2px 0 5px #0000001a;left:0;position:absolute;top:0;z-index:100}.content-area .toolbar+.area-container{margin-left:250px}@media (max-width:768px){.content-area .toolbar{width:200px}.content-area .toolbar+.area-container{margin-left:200px}}@media (max-width:480px){.content-area .toolbar{width:160px}.content-area .toolbar+.area-container{margin-left:160px}}.input-bar-container{background:#fff;border-radius:8px;bottom:20px;box-shadow:0 2px 10px #0000001a;left:50%;padding:10px;position:fixed;transform:translateX(-50%);z-index:2}.navbar,.sidebar,.toolbar{position:relative;z-index:1}.navbar{align-items:center;background-color:#fff;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;display:flex;font-family:Arial,sans-serif;justify-content:space-between;padding:12px 16px;position:fixed;top:0;width:100%;z-index:1000}.navbar-logo{height:35px;margin-left:5px;object-fit:contain}.navbar-left{align-items:center;display:flex;gap:10px}.navbar-left h1{color:#333;font-size:20px;font-weight:700;margin:0}.navbar-center{display:flex;flex-grow:1;justify-content:center;position:relative}.custom-dropdown{background-color:#f9f9f9;border:1px solid #ccc;border-radius:16px;cursor:pointer;padding:8px 12px;position:relative;text-align:left;transition:border-color .3s ease;width:150px}:root{--mathviz-green:#4bf164;--mathviz-hover:#3dd152}.custom-dropdown:hover{border-color:#4bf164;border-color:var(--mathviz-green)}.dropdown-item:hover,.hamburger-icon:hover,.hamburger-item:hover,.share-icon:hover{color:var(--mathviz-green)}.assign-button{background-color:#4bf164;background-color:var(--mathviz-green)}.assign-button:hover{background-color:#3dd152;background-color:var(--mathviz-hover)}.sign-in-button{border:1px solid var(--mathviz-green)}.sign-in-button:hover{background-color:var(--mathviz-green);border-color:#3dd152;border-color:var(--mathviz-hover)}.calculator-option:hover{border-color:#4bf164;border-color:var(--mathviz-green)}.calculator-option:hover .calculator-icon,.close-modal-button:hover{color:#4bf164;color:var(--mathviz-green)}.sign-in-btn{background-color:#4bf164;background-color:var(--mathviz-green)}.sign-in-btn:hover{background-color:#3dd152;background-color:var(--mathviz-hover)}.dropdown-selected{align-items:center;color:#333;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center}.dropdown-menu{animation:dropdown-fade .2s ease-in-out;background-color:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 3px 8px #00000026;left:0;margin-top:4px;position:absolute;top:100%;width:100%;z-index:1000}@keyframes dropdown-fade{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{align-items:center;color:#333;cursor:pointer;display:flex;font-size:13px;gap:8px;justify-content:flex-start;padding:10px 12px;transition:background-color .3s ease,color .3s ease}.dropdown-item:hover{background-color:#f5f5f5;color:#4bf164}.navbar-right{align-items:center;display:flex;gap:15px}.hamburger-icon{color:#333;cursor:pointer;font-size:18px;transition:color .3s ease}.hamburger-icon:hover{color:#4bf164}.hamburger-menu{background-color:#fff;box-shadow:0 3px 6px #0000001a;height:100%;left:0;max-width:400px;overflow-y:auto;position:fixed;top:63px;width:20%;z-index:1100}.hamburger-item{align-items:center;cursor:pointer;display:flex;font-size:15px;gap:10px;padding:12px 18px;transition:background-color .3s ease,color .3s ease}.hamburger-item:hover{background-color:#f5f5f5;color:#4bf164}.share-icon{color:gray;cursor:pointer;font-size:20px;transition:color .3s ease}.share-icon:hover{color:#4bf164}.sign-in-button{background-color:initial;border:1px solid #4bf164;border-radius:4px;color:#333;cursor:pointer;font-size:13px;font-weight:700;padding:6px 12px;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.sign-in-button:hover{background-color:#4bf164;border-color:#4bf164;color:#fff}@media (max-width:768px){.navbar-center,.navbar-right{display:none}.hamburger-menu{left:0;top:66px;width:100%}.hamburger-item{padding:10px 14px}.assign-button,.sign-in-button{margin-top:10px;padding:8px;width:100%}}@media (max-width:480px){.navbar-left h1{font-size:16px}.hamburger-item{font-size:13px;padding:8px 12px}.assign-button,.sign-in-button{font-size:12px;padding:6px}}.math{color:#068ce5}.viz{color:#4bf164}.modal-overlay{animation:fadeIn .5s ease;height:100%;width:100%}.modal-content{align-items:center;animation:gradientShift 6s infinite alternate;background:linear-gradient(135deg,#ff9a9e,#fad0c4,#fbc2eb,#a18cd1);background-size:400% 400%;border-radius:12px;box-shadow:0 6px 20px #0000004d;display:flex;flex-direction:column;height:50%;justify-content:center;padding:10px;position:relative;text-align:center;width:50%}@keyframes gradientShift{0%{background-position:0 50%}to{background-position:100% 50%}}.calculator-options{flex-direction:row;gap:20px;margin-top:20px}.calculator-option,.calculator-options{align-items:center;display:flex;justify-content:center}.calculator-option{animation:optionPop .6s ease both;background:#fff;border:2px solid #0000;border-radius:12px;cursor:pointer;flex-direction:column;padding:12px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}@keyframes optionPop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.calculator-option:hover{border-color:#ff79c6;box-shadow:0 6px 15px #0003;transform:scale(1.1)}.calculator-icon{color:#6a0dad;font-size:36px;margin-bottom:10px;transition:color .3s ease}.calculator-option:hover .calculator-icon{color:tomato}.calculator-option p{color:#333;font-size:16px;font-weight:700;margin:0}.close-modal-button{color:#333;cursor:pointer;font-size:24px;position:absolute;right:10px;top:10px;transition:transform .3s ease,color .3s ease}.close-modal-button:hover{color:#e91e63;transform:rotate(90deg)}.sign-in-btn{align-items:center;background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:8px 16px;transition:background-color .3s}.sign-in-btn:hover{background-color:#0056b3}.sign-in-btn svg{font-size:16px}.share-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.share-modal{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:500px;padding:2rem;position:relative;width:90%}.close-button{color:#666;padding:.5rem;right:1rem;top:1rem}.close-button:hover{color:#333}.share-modal h2{color:#333;margin:0 0 1.5rem}.share-link-container{display:flex;gap:.5rem;margin-bottom:1.5rem}.share-link-input{flex:1 1;font-size:.9rem;padding:.75rem}.copy-link-button,.share-link-input{border:1px solid #ddd;border-radius:4px}.copy-link-button{align-items:center;background-color:#f0f0f0;cursor:pointer;display:flex;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s}.copy-link-button:hover{background-color:#e4e4e4}.share-buttons{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.share-button{align-items:center;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;gap:.5rem;justify-content:center;padding:.75rem;transition:opacity .2s}.share-button:hover{opacity:.9}.share-button.twitter{background-color:#1da1f2}.share-button.facebook{background-color:#4267b2}.share-button.linkedin{background-color:#0077b5}.share-button.whatsapp{background-color:#25d366}.sidebar{background-color:#fff;box-shadow:0 2px 5px #1414141a;height:100vh;left:0;margin-left:0;padding-top:90px;position:fixed;width:80px}.sidebar,.sidebar-button{align-items:center;display:flex;flex-direction:column}.sidebar-button{background-color:initial;border:none;color:#333;cursor:pointer;font-size:14px;margin-bottom:20px;padding:10px;text-align:center;transition:background-color .3s ease;width:100%}.sidebar-button i{font-size:19px;margin-bottom:5px}.sidebar-button span{color:#555;font-size:12px;margin-top:5px}.sidebar-button:hover{background-color:#f0f0f0;border-radius:5px}.sidebar-button.active{background-color:#16a085;border-radius:5px;color:#fff}.graph-container{background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;height:100%;overflow:hidden;position:relative;width:100%}.graph-canvas{cursor:crosshair;height:100%;width:100%}.graph-toolbar{background-color:#ffffffe6;border-radius:4px;box-shadow:0 2px 4px #0000001a;display:flex;gap:8px;padding:8px;position:absolute;right:10px;top:10px}.graph-toolbar button{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:4px;color:#666;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.graph-toolbar button:hover{background-color:#f5f5f5;color:#333}.controls{flex-direction:column;gap:10px;right:20px;z-index:10}.controls button{align-items:center;background-color:#ffffffb3;border:none;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;padding:12px;transition:background-color .3s;width:40px}.controls button:hover{background-color:#fff}.controls button svg{color:#333;height:20px;transition:color .3s;width:20px}.controls button:hover svg{color:#007bff}.graph-controls{display:flex;flex-direction:column;gap:10px;position:absolute;right:20px;top:50%;transform:translateY(-50%);z-index:1001}.control-btn{align-items:center;background:#0000;border:none;border-radius:50%;box-shadow:0 1px 3px #0000001a;color:#333;cursor:pointer;display:flex;font-size:1.1em;height:40px;justify-content:center;transition:all .2s ease;width:40px}.control-btn:hover{background:#fff3;box-shadow:2px 2px 5px #00000026;transform:translateX(-2px)}.control-btn:active{box-shadow:0 1px 2px #0000001a;transform:translateX(0)}.control-btn.active{background:#e8f0fe;box-shadow:inset 0 1px 3px #0000001a;color:#1a73e8}.control-btn svg{height:20px;width:20px}.settings-panel{background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 5px #0000001a;min-width:200px;padding:8px 0;position:absolute;right:0;top:70px;z-index:1000}.settings-option{margin:0}.settings-option label{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;gap:12px;padding:8px 16px;transition:background-color .2s}.settings-option label:hover{background-color:#f5f5f5}.settings-icon{color:#666;flex-shrink:0;height:14px;width:14px}.settings-option input[type=checkbox],.settings-option input[type=radio]{margin:0 0 0 auto;order:1}.grid-options{border-bottom:1px solid #eee;border-top:1px solid #eee;margin:4px 0;padding:4px 0}.grid-options label{padding:6px 16px}.settings-option input[type=checkbox],.settings-option input[type=radio]{appearance:none;-webkit-appearance:none;border:2px solid #999;border-radius:2px;cursor:pointer;height:16px;outline:none;position:relative;transition:all .2s;width:16px}.settings-option input[type=radio]{border-radius:50%}.settings-option input[type=checkbox]:checked,.settings-option input[type=radio]:checked{background-color:#4caf50;border-color:#4caf50}.settings-option input[type=checkbox]:checked:after{color:#fff;content:"✓";font-size:12px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.settings-option input[type=radio]:checked:after{background-color:#fff;border-radius:50%;content:"";height:8px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:8px}.context-menu{border-radius:4px;box-shadow:0 2px 8px #00000026;padding:8px}.context-menu button{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:background-color .2s ease;width:100%}.context-menu button:hover{background-color:#f5f5f5}.color-picker{border-top:1px solid #e0e0e0;flex-direction:column;gap:4px;margin-top:8px;padding-top:8px}.color-picker button{border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;padding:6px 12px;transition:all .2s ease}.color-picker button:hover{opacity:.8}.graph-area{background:#fff;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:1000}.graph-area canvas{display:block;height:100%;width:100%}::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}.settings-dropdown{background:#fff;border:1px solid #ccc;border-radius:8px;box-shadow:0 4px 8px #0000001a;font-family:Arial,sans-serif;min-width:250px;padding:15px;position:absolute;right:2px;top:20px;z-index:1000}.settings-dropdown ul{list-style:none;margin:0;padding:10px}.settings-dropdown ul li{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;padding:10px 15px;transition:background-color .2s,color .2s}.settings-dropdown ul li:hover{background-color:#f8f9fa}.settings-dropdown ul li svg{height:16px;margin-right:10px;width:16px}.settings-dropdown ul li.checked{color:#007bff;font-weight:700}.settings-dropdown .submenu{padding-left:20px}.settings-dropdown .submenu ul li{padding:8px 10px}.settings-dropdown ul li.separator{background-color:#ddd;height:1px;margin:5px 0}.settings-dropdown button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:10px;width:100%}.settings-dropdown button:hover{background-color:#0056b3}@media (max-width:768px){.graph-container{height:100vh;margin-left:0;margin-top:0;width:100vw}.controls{right:10px;top:10px}.controls button{font-size:14px;height:35px;padding:8px;width:35px}.controls button svg{height:16px;width:16px}}@media (min-width:769px){.graph-container{height:100vh;width:100vw}.controls{right:20px;top:20px}.controls button{font-size:18px;height:40px;padding:12px;width:40px}.controls button svg{height:20px;width:20px}}.geometry-container{background:#fff}.geometry-container canvas{display:block;height:100%!important;touch-action:none;-webkit-user-select:none;user-select:none;width:100%!important}.extremum-tooltip{background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 4px #0003;font-family:Arial,sans-serif;padding:5px 10px;pointer-events:none;white-space:nowrap}.geometry-container{background-color:#fff;bottom:0;height:100vh;left:0;margin:0;overflow:hidden;padding:0;position:absolute;right:0;top:0;width:100vw}.canvas{background-color:#fff;border:2px solid #333;box-sizing:border-box;cursor:crosshair;height:500px;margin-bottom:20px;max-width:800px;transition:all .3s ease;width:100%}.controls{display:flex;gap:15px;justify-content:center;margin-right:90px;margin-top:130px;padding:10px;position:absolute;top:20px;width:3%;z-index:1}.tool-button{background-color:#007bff;border:none;border-radius:6px;box-shadow:0 2px 5px #0000001a;color:#fff;cursor:pointer;font-size:16px;padding:12px 18px;transition:background-color .3s,transform .2s ease-in-out,box-shadow .2s ease}.tool-button:hover{background-color:#0056b3;box-shadow:0 4px 8px #0003;transform:scale(1.05)}.toggle-visibility-btn{background-color:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:12px 20px;transition:background-color .3s,transform .2s ease-in-out,box-shadow .2s ease}.toggle-visibility-btn:hover{background-color:#218838;box-shadow:0 4px 8px #0003;transform:scale(1.05)}.selected-element-info{color:#333;font-size:16px;font-weight:700;margin-top:15px;text-align:center}.selected-element-info span{color:#007bff;font-weight:400}.label-input-prompt{color:#333;font-size:14px;margin-top:10px}.label-input-prompt input{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:14px;margin-top:8px;max-width:220px;padding:8px;transition:border-color .3s ease,box-shadow .2s ease;width:100%}.label-input-prompt input:focus{border-color:#007bff;box-shadow:0 0 5px #007bff80;outline:none}@media (max-width:768px){.geometry-container{padding:10px}.controls{align-items:center;flex-direction:column;gap:10px;position:static}.canvas{height:350px;max-width:none;width:100%}.toggle-visibility-btn,.tool-button{max-width:200px;width:100%}.label-input-prompt input{max-width:100%;width:100%}}@media (max-width:480px){.canvas{height:300px}.toggle-visibility-btn,.tool-button{font-size:14px;padding:10px 15px;width:100%}.label-input-prompt input{font-size:13px;padding:6px}}.geometry-canvas{background:#fff;display:block;height:100%;left:0;margin:0;padding:0;position:absolute;top:0;width:100%}.context-menu{background:#fff;border:1px solid #ccc;box-shadow:2px 2px 5px #0003;position:fixed;z-index:1000}.context-menu-item{align-items:center;cursor:pointer;display:flex;gap:8px;padding:8px 12px}.context-menu-item:hover{background-color:#f0f0f0}.color-picker{background:#fff;border:1px solid #ccc;box-shadow:2px 2px 5px #0003;display:flex;flex-wrap:wrap;gap:5px;padding:5px;position:absolute}.color-option{border-radius:50%;cursor:pointer;height:20px;transition:transform .2s;width:20px}.color-option:hover{transform:scale(1.2)}body{background-color:#f4f4f9;display:flex;flex-direction:column;font-family:Arial,sans-serif;min-height:100vh;overflow-x:hidden}.home-page{flex-grow:1;overflow:auto;padding:50px;position:relative;text-align:center;z-index:1}.header{margin-bottom:50px}.title{animation:fadeIn 1.5s ease-out;color:#333;font-size:3rem;margin-bottom:20px}.subtitle{animation:fadeIn 2s ease-out;color:#555;font-size:1.2rem}.button-container{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-bottom:50px}.resources-button,.start-button{background-color:#5c6bc0;border:none;border-radius:30px;color:#fff;cursor:pointer;font-size:1.2rem;padding:7px 30px;transition:background-color .3s ease,transform .3s ease;width:250px}.resources-button:hover,.start-button:hover{background-color:#3f51b5;transform:scale(1.05)}.resources-button:active,.start-button:active{transform:scale(.98)}.features{background-color:#fff;border-radius:10px;box-shadow:0 0 20px #0000001a;margin-top:50px;padding:30px}.features h2{font-size:2rem;margin-bottom:20px}.features ul{list-style-type:none;padding:0}.features li{color:#333;font-size:1.1rem;margin:10px 0}.footer{background-color:#333;bottom:0;color:#fff;padding:30px 0;position:relative;text-align:center;width:100%;z-index:10}.footer p{font-size:1rem;margin:0}.footer .footer-links{display:flex;gap:20px;justify-content:center;margin-top:10px}.footer a{color:#fff;font-size:1rem;text-decoration:none;transition:color .3s ease,-webkit-text-decoration .3s ease;transition:color .3s ease,text-decoration .3s ease;transition:color .3s ease,text-decoration .3s ease,-webkit-text-decoration .3s ease}.footer a:hover{color:#5c6bc0;text-decoration:underline}.footer a:active{color:#3f51b5}.home-page{display:flex;flex-direction:column;justify-content:space-between;min-height:100vh}@keyframes moveShapes{0%{transform:translate(0)}50%{transform:translate(200px,200px)}to{transform:translate(0)}}.shape{animation:moveShapes 10s ease-in-out infinite;border-radius:50%;position:absolute;z-index:-1}.shape1{background-color:#4bc0c080;height:120px;left:10%;top:20%;width:120px}.shape2{background-color:#ff638480;height:180px;left:60%;top:40%;width:180px}.shape3{background-color:#9966ff80;height:150px;left:30%;top:60%;width:150px}.shape4{background-color:#ff9f4080;height:200px;left:80%;top:70%;width:200px}.shape5{background-color:#36a2eb80;height:100px;left:90%;top:10%;width:100px}@media (max-width:768px){.footer p{font-size:.9rem}.footer .footer-links{flex-direction:column;gap:15px}.footer a{font-size:.9rem}.button-container{flex-direction:column;gap:15px}.resources-button,.start-button{font-size:1rem;padding:12px;width:80%}.title{font-size:2.5rem}.subtitle{font-size:1rem}.features h2{font-size:1.5rem}.features li{font-size:1rem}}@media (max-width:480px){.footer .footer-links a,.footer p{font-size:.8rem}.button-container{flex-direction:column;gap:10px}.resources-button,.start-button{font-size:.9rem;padding:10px;width:100%}.title{font-size:2rem}.subtitle{font-size:.9rem}.features h2{font-size:1.3rem}.features li{font-size:.9rem}}.keyboard-container{align-items:center;background-color:#f7f7fb;border-top:2px solid #ddd;bottom:0;box-shadow:0 -4px 6px #fbf9f91a;box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:200px;justify-content:center;left:0;overflow:hidden;padding:10px 0;position:fixed;right:0;width:100%;z-index:9999}.keyboard-grid{grid-gap:2px;align-items:center;display:grid;gap:2px;grid-template-columns:repeat(9,1fr);justify-items:center;max-height:100%;padding:0 16px}.key{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 1px 2px #0000001a;color:#333;cursor:pointer;display:flex;font-size:12px;height:30px;justify-content:center;padding:6px 4px;text-align:center;transition:background-color .2s;width:55px}.key:hover{background-color:#f0f0f7}.key:active{background-color:#e0e0f0;transform:scale(.95)}.close-button{color:#888;font-size:18px;font-weight:700;position:absolute;right:16px;top:10px;z-index:10000}.close-button:hover{color:#555}.keyboard-tabs{display:flex;justify-content:space-between;margin-bottom:10px}.keyboard-tabs button{background-color:#f7f7fb;border:none;cursor:pointer;font-size:14px;padding:5px 10px;transition:background-color .3s}.keyboard-tabs button.active{background-color:#ccc}@media screen and (max-width:768px){.keyboard-grid{grid-template-columns:repeat(8,1fr)}.key{font-size:10px;height:25px;padding:4px 2px}}body{margin:0;overflow:hidden;padding:0}.toggle-button{border:none;border-radius:50%;bottom:10px;bottom:40px;box-shadow:0 4px 6px #0000001a;color:#0f0f0f;cursor:pointer;font-size:24px;left:20px;padding:10px;position:fixed;transition:background-color .3s ease;z-index:9999}.toggle-button:hover{background-color:#0056b3}.toggle-button:focus{box-shadow:0 0 5px #007bff80;outline:none}.input-bar{align-items:flex-start;background-color:#fff;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:100%;left:80px;position:absolute;top:60px;width:300px;z-index:10}.watermark{bottom:20px;left:120px;opacity:.2;pointer-events:none;position:fixed;z-index:0}.watermark img{filter:grayscale(100%);height:40px;width:auto}.equation-input{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;padding:10px;width:90%}.add-button{background-color:initial;border:none;color:#555;cursor:pointer;font-size:20px}.add-button:hover{color:#000}.input-bar input{background-color:#fff;border-radius:4px;flex:1 1;font-size:16px;outline:none;padding:8px}.input-bar input:focus{border-color:#fff!important;box-shadow:none!important;outline:none!important}.equation-list{border-radius:8px;margin-top:20px;padding:10px;width:90%}.equation-item{align-items:center;background-color:#fff;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:1px;padding:2px;width:100%}.equation-actions{display:flex;gap:10px;justify-content:flex-end}.action-button{align-items:center;background-color:#fff;border:none;border-radius:50%;color:#000;cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:5px}.action-button:hover{background-color:#f0f0f0;border-radius:50%}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#e74c3c;font-size:1rem;margin-top:10px;padding:10px;text-align:center;width:100%}.equation-item button{align-items:center;background-color:#fff;border:none;border-radius:50%;color:#000;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:1px}.equation-item button:hover{background-color:#f0f0f0;border-radius:50%}.edit-buttons{display:flex;gap:10px;margin-top:10px}@media (max-width:768px){.input-bar{box-shadow:none;height:auto;left:10px;position:fixed;top:10px;width:calc(100% - 20px)}.equation-input{padding:8px;width:100%}.equation-list{width:100%}.equation-item{align-items:flex-start;flex-direction:column;padding:5px}.equation-actions{justify-content:flex-start}.edit-buttons{justify-content:center}}@media (max-width:480px){.add-button{font-size:18px}.input-bar input{font-size:14px;padding:6px}.action-button{font-size:14px;padding:4px}}.toolbar{background-color:#fffffff2;border:1px solid #ccc;border-radius:5px;box-shadow:0 4px 8px #0000001a;left:80px;max-height:calc(100vh - 80px);overflow-y:auto;padding:15px;position:absolute;top:65px;width:290px;z-index:20}.toolbar-section{margin-bottom:25px}.toolbar-section h4{color:#333;font-size:18px;margin-bottom:12px}.tools-container{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(3,1fr);justify-items:center}.tool-icon{align-items:center;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:8px;text-align:center;transition:all .3s ease;width:80px}.tool-icon:hover{transform:scale(1.05)}.tool-icon:hover .name{color:#1976d2}.tool-icon.active .name{color:#1976d2;font-weight:600}.tool-icon .icon{align-items:center;display:flex;font-size:24px;height:36px;justify-content:center;transition:all .3s ease;width:36px}.tool-icon .name{color:#555;font-size:13px;font-weight:500;margin-top:6px;overflow:hidden;text-overflow:ellipsis;transition:all .3s ease;white-space:nowrap;width:100%}.tool-image{height:28px;object-fit:contain;transition:all .3s ease;width:28px}.area-selector{background:#f1f3f5;border-radius:4px;display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem}.area-button{background:#fff;border:1px solid #dee2e6;border-radius:4px;color:#495057;cursor:pointer;flex:1 1;font-size:.875rem;padding:.5rem;transition:all .2s}.area-button:hover{background:#e9ecef}.area-button.active{background:#339af0;border-color:#1c7ed6;color:#fff}.graph-area-3d-container{display:flex;height:100%;position:relative;width:100%}.graph-area-3d{background:#f0f0f0;overflow:hidden;position:relative}.graph-area-3d canvas{display:block}.distribution-bar{background-color:#ffffffe6;border:1px solid #ddd;box-shadow:0 4px 8px #0000001a;height:100%;left:80px;max-height:calc(100vh - 80px);overflow-y:auto;padding:10px;position:absolute;top:70px;width:290px;z-index:20}.distribution-title{border-bottom:1px solid #ddd;color:#333;font-size:1.5rem;font-weight:700;margin-bottom:16px;padding-bottom:8px;text-align:center}.distribution-select{margin-bottom:16px}.distribution-select label{color:#555;display:block;font-size:1rem;margin-bottom:8px}.distribution-select select{border:1px solid #ccc;border-radius:4px;color:#333;font-size:1rem;padding:8px;width:100%}.distribution-parameters{margin-bottom:16px}.parameter-field{margin-bottom:12px}.parameter-field label{color:#555;display:block;font-size:1rem}.parameter-field input{border:1px solid #ccc;border-radius:4px;color:#333;font-size:1rem;padding:8px;width:95%}.update-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:12px;width:100%}.update-button:hover{background-color:#0056b3}.distribution-bar .parameter-field{align-items:flex-start;display:flex;flex-direction:column}.distribution-bar .parameter-field label{color:#666;font-size:.9rem;margin-bottom:5px}.distribution-bar .parameter-field input{font-size:1rem}.distribution-area{align-items:center;border-radius:10px;display:flex;flex-direction:column;justify-content:flex-start;margin:0 auto;overflow:hidden}.chart,.distribution-area{background-color:#fff;padding:20px}.chart{border-radius:8px;box-sizing:border-box;height:100%;margin-left:300px;width:90%}@media (max-width:768px){.distribution-area{max-width:100%;padding:15px}.distribution-area h3{font-size:1.5rem}.chart{padding:10px}}@media (max-width:480px){.distribution-area{padding:10px}.distribution-area h3{font-size:1.2rem}.chart{padding:8px}}.table-bar{background-color:#fffffff2;border:1px solid #ccc;border-radius:5px;box-shadow:0 4px 8px #0000001a;height:100%;left:80px;max-height:calc(100vh - 80px);max-width:290px;overflow-x:auto;overflow-y:auto;padding:15px;position:absolute;top:65px;width:-webkit-fit-content;width:fit-content;z-index:20}table{border-collapse:collapse;min-width:100px;table-layout:auto;width:100%}th{background:#f1f1f1;border:1px solid #e0e0e0;color:#333;font-weight:50;padding:12px 8px;position:relative;text-align:left}th .resize-handle{background:#0000001a;cursor:ew-resize;height:5%;position:absolute;right:-3px;top:0;width:1px}th .resize-handle:hover{background:#0003}td{border-bottom:1px solid #e0e0e0;padding:10px 8px;position:relative;text-align:left;vertical-align:middle}input[type=text]{background:#0000;border:none;color:#333;font-size:14px;outline:none;padding:6px;width:100%}input[type=text]:focus{background-color:#f9f9f9;border-bottom:2px solid #007acc}button{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin:5px 0;padding:8px 12px;transition:background .3s}button:hover{background:#45a049}.export-preview-modal{animation:slideIn .3s ease-out;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;left:50%;max-width:600px;overflow:hidden;padding:15px;position:fixed;top:50%;transform:translate(-50%,-50%);width:95%;z-index:1000}.export-preview-modal h2{font-size:1.5em;margin:0 0 15px;text-align:center}.export-preview-modal img{border:1px solid #ddd;border-radius:8px;display:block;margin:0 auto}.export-preview-modal p{color:#666;margin:20px 0;text-align:center}.modal-actions{display:flex;gap:10px;justify-content:space-between;margin-top:20px;padding:15px}.modal-actions button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;flex:1 1;font-size:1em;margin:0 5px;min-height:44px;padding:10px 20px;transition:background-color .2s ease-in-out}.modal-actions button:hover{background-color:#0056b3}.modal-actions button:last-child{background-color:#6c757d}.modal-actions button:last-child:hover{background-color:#5a6268}.export-preview-modal:before{content:"";height:100%;width:100%;z-index:-1}.export-preview-modal:before,.modal-overlay{background-color:#00000080;left:0;position:fixed;top:0}.modal-overlay{align-items:center;bottom:0;display:flex;justify-content:center;right:0;z-index:1000}.modal-container{-webkit-overflow-scrolling:touch;animation:fadeIn .3s ease;background-color:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;max-height:90vh;max-width:620px;overflow-y:auto;width:95%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:.75rem 1rem}.header-content{display:flex;flex-direction:column;gap:.25rem}.header-content h2{color:#2d3748;font-size:1.25rem;margin:0}.graph-name{color:#718096;font-size:.85rem;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:1.5rem;justify-content:center;padding:.25rem;transition:all .2s}.close-button:hover{background-color:#f7fafc;color:#2d3748}.preview-container{align-items:center;background-color:#f8f9fa;display:flex;justify-content:center;max-height:40vh;overflow:auto;padding:10px;touch-action:pan-y pinch-zoom}.preview-image{max-height:35vh;max-width:100%;object-fit:contain}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;padding:.75rem 1rem}.modal-button{border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;min-height:44px;padding:10px 20px;transition:all .2s}.cancel-button{background-color:#f7fafc;border:1px solid #e2e8f0;color:#4a5568}.cancel-button:hover{background-color:#edf2f7}.download-button{background-color:#4299e1;border:1px solid #3182ce;color:#fff}.download-button:hover{background-color:#3182ce}.format-selector{background:#f8f9fa;border-radius:6px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;gap:.25rem;margin:.5rem;padding:.5rem .75rem}.format-selector label{color:#2c3e50;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.format-selector select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%232c3e50' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:.8em;border:2px solid #e2e8f0;border-radius:4px;color:#1a202c;cursor:pointer;font-size:.9rem;padding:.35rem .5rem;transition:all .2s ease;width:100%}.format-selector select:hover{background-color:#fafafa;border-color:#cbd5e0}.format-selector select:focus{border-color:#4299e1;box-shadow:0 0 0 2px #4299e126;outline:none}.format-selector select option{font-size:.9rem;padding:.35rem}.format-description{background-color:#fff;border-radius:4px;color:#718096;font-size:.75rem;line-height:1.3;margin-top:.2rem;padding:.35rem .5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes imageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.modal-container{margin:10px;width:95%}.preview-container{max-height:250px;min-height:120px}.preview-image{max-height:230px}.modal-button{font-size:12px;padding:6px 12px}.export-preview-modal{max-width:none;width:95%}.preview-container{max-height:300px;min-height:150px}.preview-image{max-height:250px}.modal-header h2{font-size:1.1rem}.cancel-button,.download-button{font-size:.85rem;padding:8px 12px}}.auth-container{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#f8f9faf2;bottom:0;display:flex;justify-content:flex-start;left:0;min-height:100vh;padding:80px 20px 20px;position:fixed;right:0;top:0;z-index:9999}.auth-box{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin:20px auto 0;max-width:400px;padding:40px;position:relative;width:100%;z-index:10000}.auth-header{margin-bottom:30px;text-align:center}.auth-header h1{font-size:28px;margin-bottom:15px}.auth-header h2{color:#666;font-size:20px;font-weight:500;margin-bottom:20px}.math{color:#2196f3}.math,.viz{font-weight:700}.viz{color:#4caf50}.form-group{margin-bottom:20px}.input-icon-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#666;font-size:16px;left:12px;position:absolute}.form-group input{border:1px solid #ddd;border-radius:8px;font-size:16px;padding:12px 12px 12px 40px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a;outline:none}.form-options{justify-content:space-between;margin-bottom:20px}.form-options,.remember-me{align-items:center;display:flex}.remember-me{color:#666;cursor:pointer;gap:8px}.remember-me input[type=checkbox]{cursor:pointer;height:16px;width:16px}.forgot-password{color:#2196f3;font-size:14px;text-decoration:none}.forgot-password:hover{text-decoration:underline}.auth-button{background-color:#2196f3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px;transition:background-color .3s;width:100%}.auth-button:hover{background-color:#1976d2}.auth-footer{margin-top:24px;text-align:center}.auth-switch{color:#666;font-size:14px}.auth-switch a{color:#2196f3;font-weight:500;margin-left:5px;text-decoration:none}.auth-switch a:hover{text-decoration:underline}@media (max-width:480px){.auth-container{padding-top:60px}.auth-box{margin-top:10px;padding:30px 20px}.auth-header h1{font-size:24px}.auth-header h2{font-size:18px}}.google-auth-button{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:10px;justify-content:center;margin-top:10px;padding:12px;transition:background-color .3s;width:100%}.google-auth-button:hover{background-color:#f8f9fa}.google-auth-button svg{color:#4285f4}.divider{align-items:center;display:flex;margin:20px 0;text-align:center}.divider:after,.divider:before{border-bottom:1px solid #ddd;content:"";flex:1 1}.divider span{color:#666;font-size:14px;padding:0 10px}.spreadsheet-container{-webkit-overflow-scrolling:touch;background-color:#fff;box-shadow:2px 0 5px #0000001a;height:calc(100vh - 60px);left:80px;overflow-x:auto;overflow-y:auto;position:absolute;scrollbar-gutter:stable;top:60px;transition:transform .3s ease;width:300px;z-index:100}.spreadsheet{min-width:-webkit-min-content;min-width:min-content;padding:10px}.spreadsheet table{border-collapse:collapse;width:100%}.spreadsheet td,.spreadsheet th{border:1px solid #ddd;height:25px;min-width:60px;padding:0}.spreadsheet th{background-color:#f5f5f5;font-weight:400;padding:2px 4px;position:-webkit-sticky;position:sticky;text-align:center;top:0;z-index:1}.spreadsheet input{border:none;box-sizing:border-box;font-size:14px;height:100%;padding:2px 4px;width:100%}.spreadsheet input:focus{outline:2px solid #4caf50;outline-offset:-2px}.spreadsheet td:first-child,.spreadsheet th:first-child{background-color:#f5f5f5;left:0;position:-webkit-sticky;position:sticky;z-index:2}.spreadsheet thead th:first-child{z-index:3}.resources-page{background-color:#f5f5f5;bottom:0;height:100vh;left:0;margin:0 auto;max-width:1200px;overflow-y:auto;padding:2rem;position:fixed;right:0;top:0}.resources-content{margin:0 auto;max-width:1200px;padding-bottom:2rem}.resources-page h1{color:#333;font-size:2.5rem;margin-bottom:1rem}.resources-description{color:#666;margin-bottom:2rem}.resources-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.resource-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.resource-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.resource-icon{align-items:center;background:#f0f0f0;border-radius:8px;display:flex;font-size:24px;height:48px;justify-content:center;width:48px}.resource-info h2{color:#333;font-size:1.25rem;margin:0}.resource-count{color:#6366f1;font-size:.9rem;margin:0}.resource-detail{background:#fff;border-radius:12px;margin-top:2rem;padding:2rem}.resource-header{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.resource-icon.large{font-size:32px;height:64px;width:64px}.level-section{margin-bottom:2rem}.level-section h3{color:#2f855a;margin-bottom:1rem}.topics-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.topic-card{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:background-color .2s ease}.topic-card:hover{background:#f0f1f2}.topic-icon{align-items:center;background:#fff;border-radius:6px;display:flex;font-size:1.2rem;height:32px;justify-content:center;width:32px}
/*# sourceMappingURL=main.42b08fd2.css.map*/