*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}body{min-height:100vh;font-family:Spline Sans,sans-serif}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.cosmic-gradient{background:linear-gradient(135deg,#ff69b4,#8a2be2,#00bfff)}.difficulty-badge{transform:rotate(5deg)}.glass-card{border-radius:1.5rem;border-width:1px;border-color:#fff3;background-color:#ffffff1a;--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.gallery{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:2rem}@media(min-width:640px){.gallery{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.gallery{grid-template-columns:repeat(3,minmax(0,1fr))}}.gallery-card{box-shadow:0 8px 18px #00000026;position:relative;cursor:pointer;border-radius:1.5rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.gallery-card:hover{--tw-scale-x: 1.03;--tw-scale-y: 1.03;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.gallery-card .card-image{margin-bottom:1rem;aspect-ratio:1 / 1;width:100%;overflow:hidden;border-radius:1rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.gallery-card .card-image img{height:100%;width:100%;-o-object-fit:contain;object-fit:contain}.gallery-card .card-id{position:absolute;top:1.5rem;left:1.5rem;z-index:10;border-radius:1rem;background-color:#0009;padding:.25rem .75rem;font-size:.75rem;line-height:1rem;font-weight:700;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.gallery-card .card-title{margin-bottom:.25rem;font-size:1.25rem;line-height:1.75rem;font-weight:900;--tw-text-opacity: 1;color:rgb(25 35 15 / var(--tw-text-opacity, 1))}.gallery-card .card-description{margin-bottom:1rem;font-size:.875rem;line-height:1.25rem;line-height:1.625;--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.gallery-card .card-chinese{font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.gallery-card .difficulty-badge{position:absolute;top:-.75rem;right:-.75rem;z-index:10;border-radius:9999px;padding:.25rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:900;text-transform:uppercase;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transform:rotate(5deg)}.difficulty-badge.beginner{--tw-bg-opacity: 1;background-color:rgb(51 153 51 / var(--tw-bg-opacity, 1))}.difficulty-badge.intermediate{--tw-bg-opacity: 1;background-color:rgb(255 140 0 / var(--tw-bg-opacity, 1))}.difficulty-badge.advanced{--tw-bg-opacity: 1;background-color:rgb(204 51 51 / var(--tw-bg-opacity, 1))}.gallery-card .sensor-indicator{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.sensor-tag{display:flex;align-items:center;gap:.25rem;border-radius:9999px;background-color:#9eff3d33;padding:.25rem .75rem;font-size:.75rem;line-height:1rem;font-weight:700;--tw-text-opacity: 1;color:rgb(25 35 15 / var(--tw-text-opacity, 1))}.filter-bar{border-radius:1.5rem;border-width:1px;border-color:#fff3;background-color:#ffffff1a;--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:1rem}.filter-label{margin-right:.5rem;font-size:.875rem;line-height:1.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.filter-btn{display:flex;cursor:pointer;align-items:center;gap:.25rem;border-radius:9999px;border-style:none;padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:700;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.filter-btn.active{--tw-bg-opacity: 1;background-color:rgb(158 255 61 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(25 35 15 / var(--tw-text-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter-btn.active:hover{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.filter-btn:not(.active){border-width:2px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.filter-btn:not(.active):hover{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.filter-btn[data-value=beginner]:not(.active){border-color:#3933;--tw-text-opacity: 1;color:rgb(51 153 51 / var(--tw-text-opacity, 1))}.filter-btn[data-value=beginner]:not(.active):hover{--tw-bg-opacity: 1;background-color:rgb(51 153 51 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.filter-btn[data-value=intermediate]:not(.active){border-color:#ff8c0033;--tw-text-opacity: 1;color:rgb(255 140 0 / var(--tw-text-opacity, 1))}.filter-btn[data-value=intermediate]:not(.active):hover{--tw-bg-opacity: 1;background-color:rgb(255 140 0 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.filter-btn[data-value=advanced]:not(.active){border-color:#c333;--tw-text-opacity: 1;color:rgb(204 51 51 / var(--tw-text-opacity, 1))}.filter-btn[data-value=advanced]:not(.active):hover{--tw-bg-opacity: 1;background-color:rgb(204 51 51 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.filter-btn[data-value=all]:not(.active){--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1));--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.filter-btn[data-value=all]:not(.active):hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.filter-btn.sensor-btn:not(.active):not([data-value=all]){--tw-border-opacity: 1;border-color:rgb(233 213 255 / var(--tw-border-opacity, 1));--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.filter-btn.sensor-btn:not(.active):not([data-value=all]):hover{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.filter-btn .material-symbols-outlined{font-size:1rem;line-height:1.5rem}.\!modal,.modal{position:fixed;inset:0;z-index:50;display:none;overflow-y:auto;background-color:#000c;padding:1rem}.\!modal.active,.modal.active{display:flex;align-items:center;justify-content:center}.modal-content{position:relative;max-height:90vh;width:100%;max-width:56rem;overflow-y:auto;border-radius:1.5rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.close-btn{position:absolute;top:1rem;right:1.25rem;z-index:10;cursor:pointer;border-style:none;background-color:transparent;font-size:1.875rem;line-height:2.25rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.close-btn:hover{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.modal-body{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:2rem;padding:2rem}@media(min-width:768px){.modal-body{grid-template-columns:repeat(2,minmax(0,1fr))}}.modal-image img{width:100%;border-radius:1.5rem;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.modal-info h2{margin-bottom:.25rem;font-size:1.5rem;line-height:2rem;font-weight:900;--tw-text-opacity: 1;color:rgb(25 35 15 / var(--tw-text-opacity, 1))}.modal-description{margin-bottom:.75rem;font-size:1rem;line-height:1.5rem;line-height:1.625;--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.chinese-name{margin-bottom:1.5rem;font-size:1.125rem;line-height:1.75rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.action-buttons{margin-bottom:1.5rem}.btn{display:inline-flex;align-items:center;gap:.75rem;border-radius:1.5rem;padding:1rem 1.5rem;font-size:1.125rem;line-height:1.75rem;font-weight:700;text-decoration-line:none;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.btn-primary{background:linear-gradient(135deg,#ff69b4,#8a2be2,#00bfff);--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.btn-primary:hover{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.btn-icon{font-size:1.25rem;line-height:1.75rem}.coding-section,.sensors-section,.wiring-section{margin-top:1.5rem}.coding-section h3,.sensors-section h3,.wiring-section h3{margin-bottom:1rem;border-bottom-width:2px;--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1));padding-bottom:.75rem;font-size:1.125rem;line-height:1.75rem;font-weight:700;--tw-text-opacity: 1;color:rgb(25 35 15 / var(--tw-text-opacity, 1))}.coding-options{display:flex;flex-direction:column;gap:.75rem}.coding-option{display:flex;align-items:center;gap:.75rem;border-radius:1.5rem;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.75rem;--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1));text-decoration-line:none;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.coding-option:hover{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.coding-option .option-icon{display:flex;height:2.5rem;width:2.5rem;align-items:center;justify-content:center;border-radius:1.5rem;font-size:1.25rem;line-height:1.75rem}.coding-option.makecode .option-icon{--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.coding-option.python .option-icon{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.coding-option.sensor .option-icon{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.coding-option .option-text{flex:1 1 0%}.coding-option .option-title{font-size:.875rem;line-height:1.25rem;font-weight:700}.coding-option .option-subtitle{font-size:.75rem;line-height:1rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.sensor-tags{display:flex;flex-wrap:wrap;gap:.75rem}.sensor-tags .sensor-tag{border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1));padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.wiring-image-container{border-radius:1.5rem;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:1rem;text-align:center}.wiring-image-container img{max-width:100%;border-radius:1rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.empty-state{grid-column:1 / -1;padding-top:3rem;padding-bottom:3rem;text-align:center;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.empty-state .emoji{margin-bottom:1rem;font-size:3.75rem;line-height:1}.pagination a.active{--tw-bg-opacity: 1;background-color:rgb(158 255 61 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(25 35 15 / var(--tw-text-opacity, 1))}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.absolute{position:absolute}.relative{position:relative}.m-0{margin:0}.mx-4{margin-left:1rem;margin-right:1rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mr-auto{margin-right:auto}.mt-12{margin-top:3rem}.mt-4{margin-top:1rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.hidden{display:none}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.items-center{align-items:center}.gap-4{gap:1rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.border{border-width:1px}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.pb-8{padding-bottom:2rem}.text-center{text-align:center}.align-middle{vertical-align:middle}.text-2xl{font-size:1.5rem;line-height:2rem}.text-5xl{font-size:3rem;line-height:1}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-black{font-weight:900}.font-bold{font-weight:700}.italic{font-style:italic}.text-purple-300{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/40{color:#fff6}.text-white\/60{color:#fff9}.text-white\/70{color:#ffffffb3}.text-white\/80{color:#fffc}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.loading{padding-top:3rem;padding-bottom:3rem;text-align:center;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.loading-spinner{margin-left:auto;margin-right:auto;margin-bottom:1rem;height:3rem;width:3rem;border-radius:9999px;border-width:4px;border-color:#ffffff4d;--tw-border-opacity: 1;border-top-color:rgb(255 255 255 / var(--tw-border-opacity, 1));animation:spin 1s linear infinite}.lesson-images{margin-top:1rem;display:grid;gap:1rem}.wiring-images{grid-template-columns:repeat(1,minmax(0,1fr))}@media(min-width:768px){.wiring-images{grid-template-columns:repeat(2,minmax(0,1fr))}}.blocks-images{grid-template-columns:repeat(1,minmax(0,1fr))}@media(min-width:768px){.blocks-images{grid-template-columns:repeat(2,minmax(0,1fr))}}.code-images-gallery{grid-template-columns:repeat(1,minmax(0,1fr))}.content-images-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}@media(min-width:768px){.content-images-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.content-images-gallery{grid-template-columns:repeat(4,minmax(0,1fr))}}.lesson-image{width:100%;cursor:pointer;border-radius:1rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.lesson-image:hover{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.wiring-image,.blocks-image,.code-image{max-height:20rem;-o-object-fit:contain;object-fit:contain}.content-image{aspect-ratio:1 / 1;-o-object-fit:cover;object-fit:cover}.images-hint{margin-bottom:.5rem;font-size:.875rem;line-height:1.25rem;font-style:italic;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.hex-files-list{margin-top:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.hex-file-item{display:flex;align-items:center;gap:.75rem;border-radius:1rem;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.75rem}.hex-icon{font-size:1.25rem;line-height:1.75rem}.hex-name{flex:1 1 0%;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.875rem;line-height:1.25rem}.hex-download-btn{border-radius:1rem;--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity, 1));padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:700;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));text-decoration-line:none;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.hex-download-btn:hover{--tw-bg-opacity: 1;background-color:rgb(126 34 206 / var(--tw-bg-opacity, 1))}.hex-instructions{margin-top:.5rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.image-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center}.image-modal.active{display:flex}.image-modal-backdrop{position:absolute;inset:0;background-color:#000000e6}.image-modal-content{position:relative;display:flex;max-height:90vh;max-width:90vw;align-items:center;justify-content:center}.image-modal-content img{max-height:90vh;max-width:100%;border-radius:1rem;-o-object-fit:contain;object-fit:contain;--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.image-modal-close{position:absolute;top:-3rem;right:0;display:flex;height:2.5rem;width:2.5rem;cursor:pointer;align-items:center;justify-content:center;border-radius:9999px;border-width:0px;background-color:#fff3;font-size:1.5rem;line-height:2rem;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.image-modal-close:hover{background-color:#fff6}.hover\:text-purple-200:hover{--tw-text-opacity: 1;color:rgb(233 213 255 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.step-viewer{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#1a1a2e;z-index:2000;flex-direction:column}.step-viewer.active{display:flex}.step-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;background:#0000004d;color:#fff}.step-close-btn{background:#ffffff1a;border:none;color:#fff;font-size:2rem;width:50px;height:50px;border-radius:50%;cursor:pointer;transition:background .2s}.step-close-btn:hover{background:#fff3}.step-title{font-size:1.3rem;font-weight:700}.step-progress{font-size:1.1rem;background:#ffffff1a;padding:8px 20px;border-radius:20px}.step-main{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:20px;min-height:0}.step-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:3rem;width:60px;height:100px;cursor:pointer;transition:all .2s;z-index:10}.step-nav-btn:hover:not(:disabled){background:#fff3}.step-nav-btn:disabled{opacity:.3;cursor:not-allowed}.step-prev{left:10px;border-radius:0 10px 10px 0}.step-next{right:10px;border-radius:10px 0 0 10px}.step-image-container{max-width:90%;max-height:100%;position:relative;cursor:zoom-in;overflow:hidden;display:flex;align-items:center;justify-content:center}.step-image-container.zoomed{cursor:zoom-out;overflow:auto}.step-image-container img{max-width:100%;max-height:calc(100vh - 250px);-o-object-fit:contain;object-fit:contain;border-radius:10px;box-shadow:0 10px 40px #00000080;transition:transform .3s}.step-image-container.zoomed img{max-width:none;max-height:none;transform:scale(1.5);cursor:move}.step-parts-indicator{position:absolute;top:20px;left:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border-radius:25px;display:none;align-items:center;gap:10px;font-weight:700;box-shadow:0 4px 15px #667eea66;animation:pulse 2s ease-in-out infinite}.step-parts-indicator.visible{display:flex}.step-parts-indicator.faded{opacity:.5;animation:none;background:#667eea4d}.parts-icon{font-size:1.5rem}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.step-thumbnails{display:flex;gap:10px;padding:15px 20px;background:#0000004d;overflow-x:auto;scroll-behavior:smooth}.step-thumbnails::-webkit-scrollbar{height:8px}.step-thumbnails::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.step-thumbnails::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.step-thumb{flex-shrink:0;width:80px;height:60px;border-radius:8px;overflow:hidden;cursor:pointer;border:3px solid transparent;transition:all .2s;position:relative}.step-thumb:hover{border-color:#ffffff80;transform:scale(1.05)}.step-thumb.active{border-color:#667eea;box-shadow:0 0 15px #667eea80}.step-thumb.parts-thumb{border-color:#667eea80}.step-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.thumb-parts-badge{position:absolute;top:2px;right:2px;font-size:.8rem;background:#00000080;border-radius:4px;padding:2px}.step-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:#0003;color:#fff9;font-size:.9rem}.step-type-indicator{padding:5px 15px;border-radius:15px;font-weight:700}.step-type-indicator.parts{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.step-type-indicator.step{background:#ffffff1a;color:#fff}.zoom-hint{font-style:italic}@media(max-width:768px){.step-nav-btn{width:50px;height:80px;font-size:2rem}.step-prev{left:5px}.step-next{right:5px}.step-image-container img{max-height:calc(100vh - 300px)}.step-thumb{width:60px;height:45px}.step-title{font-size:1rem}}@media(hover:none){.zoom-hint{display:none}}.lesson-viewer{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#f5f5f5;z-index:2000}.lesson-viewer.active{display:flex;flex-direction:column}.lesson-header{display:flex;align-items:center;padding:15px 20px;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 5px #0000000d}.lesson-close-btn{background:#f0f0f0;border:none;font-size:1.5rem;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:background .2s;margin-right:20px}.lesson-close-btn:hover{background:#e0e0e0}.lesson-title{display:flex;align-items:center;gap:15px;font-size:1.2rem;font-weight:700;color:#333}.lesson-type-badge{padding:5px 15px;border-radius:15px;font-size:.85rem;font-weight:700}.lesson-type-badge.makecode{background:#6c5ce7;color:#fff}.lesson-type-badge.python{background:#3498db;color:#fff}.lesson-viewer.active{display:grid;grid-template-areas:"header header" "sidebar main";grid-template-columns:280px 1fr;grid-template-rows:auto 1fr}.lesson-header{grid-area:header}.lesson-sidebar{grid-area:sidebar;background:#fff;border-right:1px solid #e0e0e0;padding:20px;overflow-y:auto}.lesson-sidebar h3{font-size:1rem;color:#666;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}.lesson-list{list-style:none;margin:0;padding:0}.lesson-item{display:flex;align-items:center;gap:12px;padding:12px 15px;border-radius:10px;cursor:pointer;transition:all .2s;margin-bottom:5px}.lesson-item:hover{background:#f0f0f0}.lesson-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.lesson-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#0000001a;border-radius:50%;font-weight:700;font-size:.85rem}.lesson-item.active .lesson-number{background:#fff3}.lesson-name{flex:1;font-size:.95rem}.lesson-main{grid-area:main;overflow-y:auto;padding:30px}.lesson-content{max-width:800px;margin:0 auto}.lesson-header-content{margin-bottom:30px}.lesson-header-content h2{font-size:1.8rem;color:#333;margin-bottom:5px}.lesson-section{color:#888;font-size:.95rem}.lesson-section-block{background:#fff;border-radius:15px;padding:25px;margin-bottom:20px;box-shadow:0 2px 10px #0000000d}.lesson-section-block h3{font-size:1.1rem;color:#333;margin-bottom:15px}.lesson-section-block p{color:#666;line-height:1.6;margin-bottom:15px}.copy-block{display:flex;align-items:center;gap:10px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;padding:12px 15px}.copy-block code{flex:1;font-family:Monaco,Consolas,monospace;font-size:.9rem;color:#333;word-break:break-all}.copy-btn{display:flex;align-items:center;gap:5px;padding:8px 15px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:700;transition:all .2s;white-space:nowrap}.copy-btn:hover{background:#5a6fd6;transform:scale(1.02)}.copy-btn.copied{background:#27ae60}.code-image-placeholder{background:#f8f9fa;border:2px dashed #ddd;border-radius:10px;padding:40px;text-align:center;color:#999}.placeholder-icon{font-size:3rem;margin-bottom:15px}.placeholder-hint{font-size:.85rem;color:#bbb}.lesson-link-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 25px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:10px;font-weight:700;transition:all .2s}.lesson-link-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.lesson-link-btn.secondary{background:#f0f0f0;color:#333}.lesson-link-btn.secondary:hover{background:#e0e0e0;box-shadow:0 5px 15px #0000001a}.original-link{background:#fff8e6;border:1px solid #ffe0a6}.wiring-info{display:flex;flex-direction:column;gap:10px;background:#f8f9fa;border-radius:10px;padding:15px 20px}.wiring-item{display:flex;align-items:center;gap:10px}.wiring-label{font-weight:700;color:#555;min-width:100px}.wiring-value{color:#333;background:#fff;padding:5px 12px;border-radius:6px;border:1px solid #e0e0e0;font-family:Monaco,Consolas,monospace;font-size:.9rem}.blocks-grid{display:flex;flex-direction:column;gap:15px}.block-category{display:flex;flex-wrap:wrap;align-items:flex-start;gap:10px}.category-name{background:#667eea;color:#fff;padding:6px 14px;border-radius:20px;font-weight:700;font-size:.85rem;min-width:80px;text-align:center}.category-blocks{display:flex;flex-wrap:wrap;gap:8px;flex:1}.block-item{background:#e8f4f8;color:#2c3e50;padding:6px 12px;border-radius:6px;font-size:.85rem;font-family:Monaco,Consolas,monospace;border:1px solid #cde4ec}.code-structure{display:flex;flex-direction:column;gap:15px}.code-block{background:#f8f9fa;border-radius:10px;padding:15px 20px;border-left:4px solid #667eea}.code-block.on-start{border-left-color:#27ae60}.code-block.forever{border-left-color:#3498db}.code-block.controller{border-left-color:#e74c3c}.code-block.spider{border-left-color:#9b59b6}.code-label{display:inline-block;background:#667eea;color:#fff;padding:4px 12px;border-radius:15px;font-size:.8rem;font-weight:700;margin-bottom:10px}.code-block.on-start .code-label{background:#27ae60}.code-block.forever .code-label{background:#3498db}.code-block.controller .code-label{background:#e74c3c}.code-block.spider .code-label{background:#9b59b6}.code-content{color:#333;font-family:Monaco,Consolas,monospace;font-size:.95rem}.code-line{padding:4px 0;border-bottom:1px dashed #e0e0e0}.code-line:last-child{border-bottom:none}.python-code pre{background:#2d3436;color:#dfe6e9;border-radius:10px;padding:20px;overflow-x:auto;font-family:Monaco,Consolas,monospace;font-size:.9rem;line-height:1.6;margin-bottom:15px}.python-code pre code{white-space:pre-wrap}.lesson-section-block.phenomenon{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border:1px solid #c8e6c9}.lesson-section-block.phenomenon h3{color:#2e7d32}.lesson-section-block.objective{background:linear-gradient(135deg,#e3f2fd,#e8eaf6);border:1px solid #bbdefb}.lesson-section-block.objective h3{color:#1565c0}.lesson-section-block.original-link{display:flex;flex-direction:column;gap:15px}.lesson-section-block.original-link .lesson-link-btn{align-self:flex-start}.lesson-section-block.original-link .lesson-link-btn+.lesson-link-btn{margin-top:0}@media(max-width:768px){.lesson-viewer.active{grid-template-areas:"header" "main";grid-template-columns:1fr;grid-template-rows:auto 1fr}.lesson-sidebar{display:none}.lesson-main{padding:20px}.block-category{flex-direction:column}.wiring-item{flex-direction:column;align-items:flex-start}.wiring-label{min-width:auto}}
