*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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:#f5f5f5}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#4285f4;padding:.75rem 2rem;box-shadow:0 2px 8px #0000001a;text-align:center;color:#fff;position:relative}.app-header h1{font-family:Caveat,cursive;font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:.25rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);transform:rotate(-1deg);animation:chalkWrite 2s ease-in-out}.app-header p{color:#ffffffe6;font-size:.9rem;font-weight:300;margin-top:.25rem}.app-main{flex:1;padding:1rem 1rem 4rem;overflow:hidden}.tabs{max-width:1200px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;overflow:hidden;border:1px solid #e0e0e0}.tab-headers{display:flex;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #e9ecef}.tab-header{flex:1;padding:1.25rem 2rem;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:500;color:#666;transition:all .3s ease;position:relative}.tab-header:hover{background:#4285f41a;color:#4285f4}.tab-header.active{background:#fff;color:#4285f4;border-bottom:3px solid #4285f4;font-weight:600}.tab-content{padding:1rem}.canvas-board{display:flex;gap:1rem;height:calc(100vh - 200px);max-height:600px}.canvas-container{flex:1;display:flex;justify-content:center;align-items:flex-start}.blackboard-frame{position:relative;background:linear-gradient(135deg,#8b4513,sienna,#8b4513,#654321,#8b4513);padding:20px;border-radius:15px;box-shadow:0 0 0 8px #654321,0 0 0 12px #8b4513,0 0 0 16px #654321,0 8px 32px #0000004d,inset 0 2px 4px #ffffff1a;transform:perspective(1000px) rotateX(2deg);transition:transform .3s ease}.blackboard-frame:hover{transform:perspective(1000px) rotateX(0)}.blackboard-frame:before{content:"";position:absolute;top:-4px;left:-4px;right:-4px;bottom:-4px;background:linear-gradient(45deg,#654321,#8b4513,sienna,#8b4513);border-radius:19px;z-index:-1}.blackboard-frame canvas{border-radius:8px;box-shadow:inset 0 2px 8px #00000080;background:#1a1a1a}.panel-container{width:300px;display:flex;flex-direction:column;gap:1rem;background:#e8f5e8;padding:1rem;border-radius:12px;border:2px solid #34a853}.controls{display:flex;flex-direction:column;gap:.5rem}.control-button{padding:.75rem 1rem;border:2px solid #4285f4;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:12px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;box-shadow:0 2px 8px #4285f41a}.control-button:hover:not(:disabled){background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-color:#34a853;transform:translateY(-2px);box-shadow:0 4px 12px #4285f433}.control-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.control-button.primary{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;border-color:#4285f4;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.control-button.primary:hover:not(:disabled){background:linear-gradient(135deg,#34a853,#4285f4);border-color:#34a853;transform:translateY(-2px);box-shadow:0 4px 16px #4285f44d}.results-panel{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:12px;padding:1rem;max-height:400px;overflow-y:auto;border:2px solid #4285f4;box-shadow:0 4px 16px #4285f41a}.results-panel h3{margin-bottom:1rem;color:#4285f4;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.squares-list{display:flex;flex-direction:column;gap:.75rem}.square-item{background:#fff;border-radius:8px;padding:.75rem;border:1px solid #4285f4;box-shadow:0 2px 8px #4285f41a;transition:transform .2s ease}.square-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4285f433}.square-header{font-weight:600;color:#333;margin-bottom:.5rem}.square-coordinates{display:flex;flex-wrap:wrap;gap:.5rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8rem;color:#666}.vertex-coord{background:#f8f9fa;padding:.25rem .5rem;border-radius:3px}.toast{position:fixed;top:2rem;right:2rem;padding:1rem 1.5rem;border-radius:4px;color:#fff;font-weight:500;box-shadow:0 4px 12px #00000026;z-index:1000;display:flex;align-items:center;gap:1rem;max-width:400px}.toast-error{background:#dc3545}.toast-success{background:#28a745}.toast-info{background:#17a2b8}.toast-close{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;margin-left:auto}.theory-content{max-width:800px;margin:0 auto;line-height:1.6}.theory-content h1{color:#333;margin-bottom:1rem}.theory-content h2{color:#333;margin:2rem 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e9ecef}.theory-content h3{color:#333;margin:1.5rem 0 .75rem}.theory-content h4{color:#333;margin:1rem 0 .5rem}.theory-content p{margin-bottom:1rem;color:#555}.theory-content ul{margin-bottom:1rem;padding-left:1.5rem}.theory-content li{margin-bottom:.5rem;color:#555}.theory-content pre{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:1rem;overflow-x:auto;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;margin-bottom:1rem}.theory-content strong{color:#333;font-weight:600}.linkedin-bar{position:fixed;bottom:0;left:0;right:0;background:#0077b5;color:#fff;padding:.5rem 2rem;text-align:center;box-shadow:0 -2px 8px #0000001a;z-index:1000;transform:translateY(100%);animation:slideUp 1s ease-out 3s forwards}@keyframes slideUp{to{transform:translateY(0)}}.linkedin-bar-content{display:flex;align-items:center;justify-content:center;gap:1rem;max-width:1200px;margin:0 auto}.linkedin-bar-text{font-size:1rem;font-weight:500}.linkedin-button{background:#fff;color:#0077b5;padding:.5rem 1rem;border-radius:25px;text-decoration:none;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #0003}.linkedin-button:hover{background:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.linkedin-button:active{transform:translateY(0)}@media (max-width: 768px){.canvas-board{flex-direction:column}.panel-container{width:100%}.app-main,.tab-content{padding:1rem}.linkedin-bar-content{flex-direction:column;gap:.5rem}.app-header h1{font-size:2rem}.app-main{padding-bottom:3rem}}
