*{box-sizing:border-box;margin:0;padding:0}:root{--primary-blue:#2563eb;--primary-blue-dark:#1e40af;--primary-blue-light:#3b82f6;--accent-orange:#f97316;--accent-orange-dark:#ea580c;--accent-orange-light:#fb923c;--text-dark:#1f2937;--text-light:#6b7280;--bg-white:#fff;--bg-light:#f9fafb;--dark-blue:#0f172a;--dark-blue-light:#1e293b;--dark-blue-header:#0a1628}.theme-normal .hero{background:linear-gradient(135deg,var(--primary-blue)0%,var(--primary-blue-light)100%);color:#fff;transition:background 1s,color 1s}.theme-normal .hero-logo-title{background:linear-gradient(135deg,var(--primary-blue)0%,var(--primary-blue-light)100%);transition:background 1s,border 1s}.theme-white .hero{color:var(--text-dark);background:#fff;transition:background 1s,color 1s}.theme-white .hero-logo-title{border:2px solid var(--primary-blue);background:#fff;transition:background 1s,border 1s}.theme-white .hero-title,.theme-white .hero-tagline{color:var(--text-dark);transition:color 1s}.theme-dark .hero{background:linear-gradient(135deg,var(--dark-blue)0%,var(--dark-blue-light)100%);color:#fff;transition:background 1s,color 1s}.theme-dark .hero-logo-title{background:linear-gradient(135deg,var(--dark-blue)0%,var(--dark-blue-light)100%);transition:background 1s,border 1s}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-dark);perspective:1000px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;overflow-x:hidden}.main-container{min-height:100vh;position:relative}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.header{background:var(--bg-white);z-index:100;transition:background 1s,box-shadow 1s;position:sticky;top:0;box-shadow:0 2px 4px #0000001a}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex}.logo-container{align-items:center;display:flex}.logo{width:auto;height:100px;transition:transform .3s}.logo:hover{transform:scale(1.05)}.hero-logo-title{background:linear-gradient(135deg,var(--primary-blue)0%,var(--primary-blue-light)100%);border-radius:12px;flex-wrap:wrap;align-items:center;gap:2rem;margin-bottom:1.5rem;padding:2rem;transition:background .3s,border .3s;display:flex}.hero-student-image{flex-shrink:0}.hero-student-photo{object-fit:cover;border-radius:12px;width:100%;max-width:500px;height:auto;transition:transform .3s;box-shadow:0 8px 24px #0003}.hero-student-photo:hover{transform:scale(1.02)}.nav-buttons{align-items:center;gap:1rem;display:flex}.btn{cursor:pointer;transform-style:preserve-3d;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-block;position:relative;overflow:hidden}.btn:before{content:"";background:#ffffff4d;border-radius:50%;width:0;height:0;transition:width .6s,height .6s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.btn:hover:before{width:300px;height:300px}.btn-login{color:var(--primary-blue);border:2px solid var(--primary-blue);background:0 0}.btn-login:hover{background:var(--primary-blue);color:#fff;transform:translateY(-2px)scale(1.05);box-shadow:0 8px 16px #2563eb4d}.btn-signup{background:var(--primary-blue);color:#fff}.btn-signup:hover{background:var(--primary-blue-dark);transform:translateY(-3px)scale(1.05)rotateX(5deg);box-shadow:0 8px 20px #2563eb66}.btn-primary{background:var(--primary-blue);color:#fff;padding:1rem 2rem;font-size:1.1rem}.btn-primary:hover{background:var(--primary-blue-dark);transform:translateY(-3px)scale(1.05)rotateX(5deg);box-shadow:0 8px 20px #2563eb66}.btn-secondary{background:var(--accent-orange);color:#fff;padding:1rem 2rem;font-size:1.1rem}.btn-secondary:hover{background:var(--accent-orange-dark);transform:translateY(-3px)scale(1.05)rotateX(5deg);box-shadow:0 8px 20px #f9731666}.btn-large{padding:1.25rem 2.5rem;font-size:1.2rem}.hero{background:linear-gradient(135deg,var(--primary-blue)0%,var(--primary-blue-light)100%);color:#fff;min-height:100vh;transform-style:preserve-3d;align-items:center;padding:6rem 0 8rem;transition:background .3s,color .3s;display:flex;position:relative;overflow:hidden}.hero-container{z-index:1;max-width:1200px;transform-style:preserve-3d;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;margin:0 auto;padding:0 1.5rem;display:grid;position:relative}.hero-content{transform-style:preserve-3d;transition:transform .1s ease-out;animation:.8s fadeInUp}.hero-title{flex:1;margin:0;font-size:3.5rem;font-weight:800;line-height:1.2}.hero-tagline{opacity:.95;color:#fff;margin-bottom:2.5rem;font-size:1.5rem;line-height:1.6}.hero-buttons{flex-wrap:wrap;gap:1.5rem;margin-bottom:4rem;display:flex}.hero-image{transform-style:preserve-3d;justify-content:center;align-items:center;transition:transform .1s ease-out;animation:1s fadeIn;display:flex;position:relative}.floating-shapes{width:100%;height:400px;position:relative}.shape{filter:blur(1px);border-radius:50%;animation:6s ease-in-out infinite float;position:absolute}.shape-1{background:var(--accent-orange);opacity:.6;width:120px;height:120px;animation-delay:0s;top:15%;left:8%;box-shadow:0 0 40px #f9731680}.shape-2{opacity:.5;background:#fff6;width:180px;height:180px;animation-delay:1.5s;top:45%;right:15%;box-shadow:0 0 50px #ffffff4d}.shape-3{background:var(--accent-orange-light);opacity:.55;width:100px;height:100px;animation-delay:3s;bottom:25%;left:45%;box-shadow:0 0 35px #fb923c80}.shape-4{opacity:.45;background:#93c5fd80;width:90px;height:90px;animation-delay:4.5s;top:60%;left:25%;box-shadow:0 0 30px #93c5fd66}.shape-5{opacity:.4;background:#ffffff59;width:110px;height:110px;animation-delay:2.5s;top:30%;right:40%;box-shadow:0 0 35px #ffffff40}.shape-6{opacity:.5;background:#fb923c80;width:85px;height:85px;animation-delay:5.5s;bottom:40%;right:25%;box-shadow:0 0 28px #fb923c66}.shape-7{background:var(--accent-orange);opacity:.65;width:130px;height:130px;animation-delay:1s;top:5%;right:30%;box-shadow:0 0 45px #f9731699}.shape-8{opacity:.5;background:#60a5fa99;width:95px;height:95px;animation-delay:3.5s;bottom:15%;left:15%;box-shadow:0 0 32px #60a5fa80}.shape-9{opacity:.4;background:#ffffff4d;width:140px;height:140px;animation-delay:4s;top:70%;right:5%;box-shadow:0 0 42px #ffffff4d}.shape-10{opacity:.45;background:#fb923c8c;width:75px;height:75px;animation-delay:6s;top:50%;left:60%;box-shadow:0 0 25px #fb923c73}.shape-11{opacity:.35;background:#93c5fd73;width:105px;height:105px;animation-delay:2s;bottom:10%;right:50%;box-shadow:0 0 30px #93c5fd59}.shape-12{background:var(--accent-orange-light);opacity:.5;width:115px;height:115px;animation-delay:5s;top:25%;left:70%;box-shadow:0 0 38px #fb923c80}.features{background:var(--bg-light);transform-style:preserve-3d;padding:6rem 0;position:relative}.section-title{text-align:center;color:var(--text-dark);transform-style:preserve-3d;margin-bottom:3rem;font-size:2.5rem;font-weight:700;transition:transform .3s}.section-title:hover{transform:scale(1.05)rotateY(5deg)}.features-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:stretch;gap:2rem;display:grid}.feature-card{text-align:center;transform-style:preserve-3d;background:#fff;border-radius:12px;flex-direction:column;justify-content:space-between;height:100%;padding:2.5rem;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px #0000001a}.feature-card:before{content:"";background:linear-gradient(90deg,#0000,#2563eb1a,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.feature-card:hover:before{left:100%}.feature-card:hover{transform:translateY(-12px)rotateX(5deg)rotateY(5deg)scale(1.02);box-shadow:0 20px 40px #0003,0 0 30px #2563eb1a}.feature-icon{margin-bottom:1rem;font-size:3rem;transition:transform .4s cubic-bezier(.68,-.55,.265,1.55);display:inline-block}.feature-card:hover .feature-icon{transform:scale(1.2)rotateY(360deg)}.feature-card h3{color:var(--primary-blue);margin-bottom:1rem;font-size:1.5rem}.feature-card p{color:var(--text-light);line-height:1.6}.cta{background:linear-gradient(135deg,var(--accent-orange)0%,var(--accent-orange-light)100%);color:#fff;text-align:center;padding:6rem 0}.cta h2{margin-bottom:1rem;font-size:2.5rem;font-weight:700}.cta p{opacity:.95;margin-bottom:2rem;font-size:1.25rem}.footer{background:var(--text-dark);color:#fff;text-align:center;padding:2rem 0}.robot-follower{pointer-events:all;cursor:pointer;z-index:9999;width:90px;height:90px;transform-style:preserve-3d;transition:opacity .3s,transform .3s;position:fixed}.robot-follower.robot-excited{animation:none}.robot-follower.robot-excited .robot-body{animation:.4s ease-in-out infinite robotShake}.robot-follower.robot-excited .robot-head{animation:.5s ease-in-out infinite robotHeadBob;transform:scale(1.05)}.robot-follower.robot-excited .robot-antenna{animation:.5s ease-in-out infinite antennaWiggle}.robot-follower.robot-excited .robot-eye{animation:.2s ease-in-out infinite excitedBlink;transform:scale(1.3)}.robot-body{width:100%;height:100%;transform-style:preserve-3d;position:relative}.robot-head{z-index:2;background:#93c5fd;border:3px solid #1e40af;border-radius:8px;width:80px;height:40px;margin:0 auto;position:relative;box-shadow:0 2px 4px #0003}.robot-antenna{z-index:3;background:#1e40af;border-radius:2px;width:3px;height:12px;animation:2s ease-in-out infinite antennaWiggle;position:absolute;top:-12px;right:10px}.robot-face{background:#fff;border-radius:50%;justify-content:center;align-items:center;gap:6px;width:32px;height:24px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.robot-eye{background:#1e40af;border-radius:50%;width:5px;height:5px;margin-top:2px;animation:3s infinite blink;position:relative}.robot-body-base{z-index:1;background:#93c5fd;border:3px solid #1e40af;border-radius:12px 12px 0 0;width:36px;height:calc(100% - 40px);position:absolute;top:40px;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #0003}.robot-body-base:after{content:"";background:#93c5fd;border:3px solid #1e40af;border-top:none;border-radius:0 0 14px 14px;width:40px;height:8px;position:absolute;bottom:-8px;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #0003}.robot-follower.robot-impatient .robot-eye{animation:.2s ease-in-out infinite impatientBlink}.robot-follower.robot-impatient .robot-head{animation:.4s ease-in-out infinite impatientBob}.robot-follower.robot-impatient .robot-body-base{animation:.5s ease-in-out infinite impatientFidget}.robot-follower.robot-impatient .robot-antenna{animation:.3s ease-in-out infinite antennaWiggle}.robot-follower.robot-tired .robot-face:after{content:"💧";font-size:10px;animation:1s ease-in-out infinite sweatDrop;position:absolute;top:-8px;right:-8px}.robot-follower.robot-tired .robot-eye{animation:2s ease-in-out infinite tiredBlink;transform:scaleY(.3)}.robot-follower.robot-happy .robot-eye{background:0 0;width:0;height:0;position:relative}.robot-follower.robot-happy .robot-eye-left:after{content:">";color:#1e40af;font-size:12px;font-weight:700;line-height:1;position:absolute;top:-3px;left:-3px}.robot-follower.robot-happy .robot-eye-right:after{content:"<";color:#1e40af;font-size:12px;font-weight:700;line-height:1;position:absolute;top:-3px;left:3px}.robot-follower.robot-happy .robot-head{animation:.6s ease-in-out infinite happyBounce}.scroll-animate{opacity:0;transform-style:preserve-3d;transition:all .8s cubic-bezier(.4,0,.2,1);transform:translateY(50px)rotateX(20deg)}.scroll-animate.animate-in{opacity:1;transform:translateY(0)rotateX(0)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)rotate(0)}33%{transform:translateY(-20px)rotate(120deg)}66%{transform:translateY(20px)rotate(240deg)}}@keyframes backgroundPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes antennaWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(5deg)}75%{transform:rotate(-5deg)}}@keyframes blink{0%,90%,to{transform:scaleY(1)}95%{transform:scaleY(.1)}}@keyframes robotBounce{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-10px)scale(1.15)}}@keyframes robotShake{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(-2px)rotate(-2deg)}75%{transform:translate(2px)rotate(2deg)}}@keyframes robotHeadBob{0%,to{transform:translateY(0)rotate(0)scale(1.05)}50%{transform:translateY(-3px)rotate(3deg)scale(1.05)}}@keyframes excitedBlink{0%,50%,to{opacity:1;transform:scale(1.3)}25%,75%{opacity:.8;transform:scale(1.5)}}@keyframes impatientBlink{0%,50%,to{opacity:1}25%,75%{opacity:.3}}@keyframes impatientBob{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-3px)rotate(-5deg)}50%{transform:translateY(-1px)rotate(0)}75%{transform:translateY(-3px)rotate(5deg)}}@keyframes sweatDrop{0%{opacity:0;transform:translateY(0)}50%{opacity:1}to{opacity:0;transform:translateY(8px)}}@keyframes tiredBlink{0%,90%,to{transform:scaleY(.3)}95%{transform:scaleY(.1)}}@keyframes happyBounce{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-8px)scale(1.1)}}@keyframes impatientFidget{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(-2px)rotate(-2deg)}50%{transform:translate(0)rotate(0)}75%{transform:translate(2px)rotate(2deg)}}@media (max-width:768px){.hero-container{text-align:center;grid-template-columns:1fr}.hero-logo-title{flex-direction:column;align-items:center;gap:1rem}.hero-student-photo{max-width:100%;height:auto}.hero-title{text-align:center;font-size:2.5rem}.hero-tagline{font-size:1.25rem}.hero-buttons{justify-content:center}.nav-container{flex-direction:column;gap:1rem}.nav-buttons{justify-content:center;width:100%}.features-grid{grid-template-columns:1fr}.section-title,.cta h2{font-size:2rem}}.theme-selector{z-index:10000;border:3px solid var(--primary-blue);background:#fff;border-radius:12px;flex-direction:column;gap:.5rem;width:150px;padding:1rem;font-size:.85rem;display:flex;position:fixed;top:120px;right:20px;box-shadow:0 4px 20px #0000004d}.theme-buttons{flex-direction:column;gap:.5rem;display:flex}.theme-selector:before{content:"Theme";color:var(--primary-blue);text-transform:uppercase;letter-spacing:1px;margin-bottom:.25rem;font-size:.75rem;font-weight:700;display:block}.theme-btn{color:var(--text-dark);cursor:pointer;white-space:nowrap;background:#fff;border:2px solid #0000;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .3s;display:flex}.theme-btn:hover{background:var(--bg-light);transform:translate(-2px)}.theme-btn.active{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue-dark)}.theme-color{border:2px solid #0003;border-radius:50%;width:20px;height:20px;display:inline-block}.theme-color.normal{background:linear-gradient(135deg,var(--primary-blue)0%,var(--primary-blue-light)100%)}.theme-color.white{background:#fff}.theme-color.dark{background:linear-gradient(135deg,var(--dark-blue)0%,var(--dark-blue-light)100%)}.robot-toggle-selector{z-index:10000;border:3px solid var(--primary-blue);background:#fff;border-radius:12px;width:150px;padding:1rem;font-size:.85rem;position:fixed;top:350px;right:20px;box-shadow:0 4px 20px #0000004d}.robot-toggle-selector:before{content:"Show Pet";color:var(--primary-blue);text-transform:uppercase;letter-spacing:1px;margin-bottom:.75rem;font-size:.75rem;font-weight:700;display:block}.toggle-container{justify-content:center;align-items:center;gap:1rem;display:flex}.toggle-switch{cursor:pointer;width:50px;height:26px;position:relative}.toggle-input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{cursor:pointer;background-color:#ccc;border-radius:26px;transition:background-color .3s;position:absolute;inset:0}.toggle-slider.on{background-color:var(--primary-blue)}.toggle-slider.off{background-color:#ccc}.toggle-knob{background-color:#fff;border-radius:50%;width:20px;height:20px;transition:transform .3s;position:absolute;top:3px;left:3px;box-shadow:0 2px 4px #0003}.toggle-slider.on .toggle-knob{transform:translate(24px)}.toggle-slider.off .toggle-knob{transform:translate(0)}@media (max-width:768px){.robot-toggle-selector{width:150px;top:350px;right:10px}.theme-selector{flex-direction:row;padding:.5rem;top:120px;right:10px}.theme-btn{padding:.4rem .8rem;font-size:.8rem}.theme-btn .theme-color{display:none}}.btn-demo{background:var(--accent-orange);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .3s}.btn-demo:hover{background:var(--accent-orange-dark);transform:translateY(-2px);box-shadow:0 4px 12px #f973164d}.demo-code-panel{z-index:10001;border:3px solid var(--primary-blue);background:#fff;border-radius:16px;flex-direction:column;width:500px;max-height:600px;display:flex;position:fixed;bottom:20px;left:20px;box-shadow:0 8px 32px #0003}.demo-code-header{background:var(--primary-blue);color:#fff;border-radius:13px 13px 0 0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.demo-code-header h3{margin:0;font-size:1.2rem;font-weight:700}.demo-close-btn{color:#fff;cursor:pointer;background:0 0;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:1.5rem;line-height:1;transition:all .3s;display:flex}.demo-close-btn:hover{color:var(--primary-blue);background:#fff}.demo-code-content{grid-template-columns:1fr 1fr;gap:1.5rem;max-height:500px;padding:1.5rem;display:grid;overflow-y:auto}.demo-blocks-palette{border-right:2px solid var(--bg-light);padding-right:1.5rem}.demo-blocks-palette h4,.demo-workspace h4{color:var(--text-dark);margin:0 0 1rem;font-size:1rem;font-weight:600}.block-buttons{flex-direction:column;gap:.75rem;display:flex}.block-btn{border:2px solid var(--primary-blue);color:var(--primary-blue);cursor:pointer;text-align:left;background:#fff;border-radius:8px;padding:.75rem 1rem;font-size:.9rem;font-weight:600;transition:all .3s}.block-btn:hover{background:var(--primary-blue);color:#fff;transform:translate(5px)}.demo-workspace{flex-direction:column;display:flex}.blocks-container{border:2px dashed var(--bg-light);background:var(--bg-light);border-radius:8px;min-height:200px;max-height:300px;margin-bottom:1rem;padding:1rem;overflow-y:auto}.empty-workspace{text-align:center;color:var(--text-light);margin:2rem 0;font-style:italic}.code-block{border:2px solid var(--primary-blue);cursor:move;background:#fff;border-radius:8px;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem;transition:all .3s;display:flex}.code-block:hover{transform:translate(3px);box-shadow:0 4px 8px #0000001a}.code-block[data-type=up]{border-left:4px solid #10b981}.code-block[data-type=down]{border-left:4px solid #3b82f6}.code-block[data-type=left]{border-left:4px solid #f59e0b}.code-block[data-type=right]{border-left:4px solid #ef4444}.block-number{background:var(--primary-blue);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.block-label{color:var(--text-dark);flex:1;font-weight:600}.remove-block{color:var(--text-light);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.25rem;transition:all .3s;display:flex}.remove-block:hover{color:#dc2626;background:#fee2e2}.demo-actions{gap:.75rem;display:flex}.demo-clear-btn,.demo-run-btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:.75rem 1rem;font-size:1rem;font-weight:600;transition:all .3s}.demo-clear-btn{background:var(--bg-light);color:var(--text-dark);border:2px solid var(--text-light)}.demo-clear-btn:hover:not(:disabled){background:var(--text-light);color:#fff}.demo-clear-btn:disabled{opacity:.5;cursor:not-allowed}.demo-run-btn{background:var(--accent-orange);color:#fff}.demo-run-btn:hover:not(:disabled){background:var(--accent-orange-dark);transform:translateY(-2px);box-shadow:0 4px 12px #f973164d}.demo-run-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.demo-code-panel{width:calc(100% - 40px);max-height:80vh;left:20px;right:20px}.demo-code-content{grid-template-columns:1fr;gap:1rem}.demo-blocks-palette{border-right:none;border-bottom:2px solid var(--bg-light);padding-bottom:1.5rem;padding-right:0}}
