/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-slate-600:oklch(44.6% .043 257.281);--color-slate-700:oklch(37.2% .044 257.287);--color-slate-800:oklch(27.9% .041 260.031);--spacing:.25rem;--container-xl:36rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--tracking-tight:-.025em;--leading-relaxed:1.625;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.inset-0{inset:calc(var(--spacing) * 0)}.-z-10{z-index:calc(10 * -1)}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing) * 0)}.mx-auto{margin-inline:auto}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mt-10{margin-top:calc(var(--spacing) * 10)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.mb-14{margin-bottom:calc(var(--spacing) * 14)}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-xl{max-width:var(--container-xl)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:var(--radius-2xl)}.border{border-style:var(--tw-border-style);border-width:1px}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-10{padding:calc(var(--spacing) * 10)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-14{padding-block:calc(var(--spacing) * 14)}.py-24{padding-block:calc(var(--spacing) * 24)}.pt-28{padding-top:calc(var(--spacing) * 28)}.pb-24{padding-bottom:calc(var(--spacing) * 24)}.pb-28{padding-bottom:calc(var(--spacing) * 28)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-slate-600{color:var(--color-slate-600)}.text-slate-700{color:var(--color-slate-700)}.text-slate-800{color:var(--color-slate-800)}.line-through{text-decoration-line:line-through}.no-underline{text-decoration-line:none}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.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,)}}.container{width:100%;max-width:72rem;margin-inline:auto;padding-inline:1.5rem}.container--narrow{max-width:56rem}.container--cta{max-width:48rem}.flex{display:flex}.inline-flex{display:inline-flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-7{gap:1.75rem}.gap-16{gap:4rem}.grid{display:grid}.grid-1{grid-template-columns:1fr}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.p-3{padding:.75rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-10{padding:2.5rem}.px-6{padding-inline:1.5rem}.py-3{padding-block:.75rem}.py-4{padding-block:1rem}.py-14{padding-block:3.5rem}.py-24{padding-block:6rem}.pt-24{padding-top:6rem}.pt-28{padding-top:7rem}.pb-16{padding-bottom:4rem}.pb-24{padding-bottom:6rem}.pb-28{padding-bottom:7rem}.m-0{margin:0}.mx-auto{margin-inline:auto}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-10{margin-top:2.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-14{margin-bottom:3.5rem}.w-full{width:100%}.min-h-screen{min-height:100vh}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.inset-x-0{left:0;right:0}.top-0{top:0}.-z-10{z-index:-10}.z-40{z-index:40}.z-50{z-index:50}.text-center{text-align:center}.text-left{text-align:left}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.text-5xl{font-size:3rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.tracking-tight{letter-spacing:-.025em}.leading-relaxed{line-height:1.625}.uppercase{text-transform:uppercase}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;min-width:0;max-width:100%;display:-webkit-box;overflow:hidden}.line-through{text-decoration:line-through}.no-underline{text-decoration:none}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-primary{color:var(--text-primary)}.hidden{display:none}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.whitespace-nowrap{white-space:nowrap}.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.border-b{border-bottom-style:solid;border-bottom-width:1px}.pointer-events-none{pointer-events:none}.will-change-transform{will-change:transform}.opacity-40{opacity:.4}.opacity-55{opacity:.55}.hero-section{align-items:center;min-height:100vh;padding:6rem 1.5rem 4rem;display:flex}.hero-grid{align-items:center;gap:4rem;width:100%;max-width:72rem;margin-inline:auto;display:grid}.hero-title{margin-bottom:1.5rem;font-size:clamp(2.75rem,6vw,4.25rem)}.hero-subtitle{color:var(--text-secondary);max-width:32rem;margin-bottom:2.5rem;font-size:1.125rem;line-height:1.7}.page-title{margin-bottom:1rem;font-size:clamp(2.25rem,5vw,3rem)}.catalogue-grid{grid-template-columns:1fr;gap:1.75rem;min-width:0;display:grid}.catalogue-grid>*{min-width:0;max-width:100%}.steps-grid{grid-template-columns:1fr;gap:1.5rem;min-width:0;display:grid}.steps-grid>*{min-width:0;max-width:100%}.hero-stage{flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:420px;margin-inline:auto;display:flex}.hero-stage__frame{width:100%;padding:.75rem;overflow:hidden}.hero-stage__chrome{align-items:center;gap:.5rem;margin-bottom:.75rem;padding:0 .25rem;display:flex}.hero-stage__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.hero-stage__dot--red{background:#f87171}.hero-stage__dot--amber{background:#fbbf24}.hero-stage__dot--green{background:#4ade80}.hero-stage__title{color:var(--text-muted);margin-left:.25rem;font-size:.75rem;font-weight:600}.hero-stage__canvas{cursor:crosshair;touch-action:none;border:3px solid #4c97ff;border-radius:12px;width:100%;max-width:400px;height:auto;margin-inline:auto;display:block;box-shadow:inset 0 0 0 1px #ffffff80,0 8px 24px #4c97ff33}.hero-stage__hint{text-align:center;color:var(--highlight-purple);margin:.75rem 0 0;font-size:.8125rem;font-weight:600}.hero-stage__score-pill{box-shadow:var(--card-shadow);background:#ffffffbf;border:1px solid #7c3aed33;border-radius:9999px;align-items:center;gap:.75rem;padding:.5rem 1.25rem;display:flex}.hero-stage__score-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.hero-stage__score-value{color:var(--highlight-purple);text-align:center;min-width:2ch;font-size:1.5rem;font-weight:800}.hero-stage__flag-hint{color:var(--text-muted);margin:0;font-size:.75rem}.navbar{z-index:50;inset-inline:0;transition:all .3s;position:fixed;top:0}.navbar--solid{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffc7;border-bottom:1px solid #ffffffb3;box-shadow:0 1px 3px #0f172a0a}.navbar--transparent{background:0 0}.navbar__inner{justify-content:space-between;align-items:center;max-width:72rem;margin-inline:auto;padding:1rem 1.5rem;display:flex}.navbar__brand{color:var(--text-primary);align-items:center;gap:.75rem;font-size:1.05rem;font-weight:700;text-decoration:none;display:flex}.blob--tl{width:600px;height:600px;top:-12rem;left:-12rem}.blob--tr{width:550px;height:550px;top:-8rem;right:-12rem}.blob--bc{width:700px;height:600px;bottom:0;left:50%}.tutorial-step-content{scroll-margin-top:9.5rem}.step-nav{z-index:40;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffd1;border-bottom:1px solid #0f172a0f;margin-inline:-1.5rem;padding:.75rem 1.5rem;position:sticky;top:72px}.step-nav__inner{gap:.5rem;max-width:56rem;margin-inline:auto;display:flex;overflow-x:auto}.step-pill{white-space:nowrap;cursor:pointer;min-height:44px;color:var(--text-secondary);background:#0f172a0f;border:none;border-radius:9999px;flex-shrink:0;align-items:center;gap:.5rem;padding:.625rem 1.125rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.step-pill:hover{color:var(--text-primary);background:#0f172a1a}.step-pill--active{color:#fff;background:linear-gradient(135deg,#7c3aed,#6366f1);box-shadow:0 4px 14px #7c3aed4d}.step-pill__tick{color:#fff;background:#10b981;border-radius:9999px;justify-content:center;align-items:center;width:1rem;height:1rem;font-size:.625rem;display:flex}.tutorial-header{flex-direction:column;gap:1.5rem;margin-bottom:2.5rem;display:flex}@media (width>=640px){.tutorial-header{flex-direction:row;align-items:flex-start}}.tutorial-header__meta{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.task-list{background:#ffffff80;border:1px solid #0f172a0f;border-radius:1rem;flex-direction:column;gap:.25rem;max-width:100%;padding:.75rem;display:flex;overflow:hidden}.task-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:.75rem;align-items:center;gap:.75rem;width:100%;min-width:0;max-width:100%;min-height:44px;padding:.75rem 1rem;display:flex}.task-item__checkbox{color:#fff;background:#fff;border:2px solid #e2e8f0;border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;width:2rem;min-width:44px;height:2rem;min-height:44px;transition:all .2s;display:flex}.task-item__checkbox--done{background:#10b981;border-color:#10b981}.task-item__text{overflow-wrap:break-word;word-wrap:break-word;flex:1;min-width:0;font-size:1.125rem;line-height:1.625}.save-point{color:#065f46;overflow-wrap:break-word;background:#ecfdf5cc;border:1px solid #10b98140;border-radius:1rem;gap:.75rem;max-width:100%;margin-top:2.5rem;padding:1rem 1.25rem;font-size:1rem;display:flex;overflow:hidden}.save-point p{font-size:1rem}.save-point>div{flex:1;min-width:0}.breadcrumb{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.875rem;display:flex}.breadcrumb a{color:var(--text-muted);font-weight:500;text-decoration:none;transition:color .2s}.breadcrumb a:hover{color:#7c3aed}@media (width>=640px){.catalogue-grid{grid-template-columns:repeat(2,1fr)}.sm-flex-row{flex-direction:row}.sm-items-start{align-items:flex-start}.show-sm{display:inline}.hide-sm{display:none}}@media (width<=639px){.show-sm{display:none}.hide-sm{display:inline}}@media (width>=768px){.steps-grid{grid-template-columns:repeat(3,1fr)}.text-3xl-md{font-size:1.875rem}.p-10-md{padding:2.5rem}}@media (width<=768px){.step-nav{margin-inline:-1rem;padding:.5rem 1rem}.step-nav__inner{-webkit-overflow-scrolling:touch;gap:.375rem;padding-bottom:.25rem}.step-pill{padding:.5rem .875rem;font-size:.9375rem}.filter-bar{border-radius:1rem;flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%;max-width:100%;padding:.5rem;display:flex}}.tutorial-nav-buttons .btn{min-width:44px;min-height:44px;font-size:1rem}@media (width>=1024px){.hero-grid{grid-template-columns:1fr 1fr}.catalogue-grid{grid-template-columns:repeat(3,1fr)}}.print-page{background:#e2e8f0;min-height:100vh;padding:1.5rem}.print-toolbar{background:#fff;border-radius:14px;flex-wrap:wrap;align-items:center;gap:.75rem;max-width:48rem;margin:0 auto 1.5rem;padding:1rem 1.25rem;display:flex;box-shadow:0 4px 20px #0f172a14}.print-toolbar__hint{width:100%;color:var(--text-secondary);margin:0;font-size:.8125rem}.print-sheet{max-width:48rem;color:var(--text-primary);background:#fff;border-radius:8px;margin-inline:auto;padding:2rem 2.25rem;box-shadow:0 8px 32px #0f172a1a}.print-sheet__header{border-bottom:2px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1.5rem}.print-sheet__brand{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.print-sheet__site{text-transform:uppercase;letter-spacing:.06em;color:var(--highlight-purple);margin:0 0 .25rem;font-size:.75rem;font-weight:700}.print-sheet__title{margin:0;font-size:1.75rem;font-weight:800;line-height:1.2}.print-sheet__meta{color:var(--text-secondary);flex-wrap:wrap;gap:1rem;margin-bottom:.75rem;font-size:.875rem;font-weight:600;display:flex}.print-sheet__desc{color:var(--text-secondary);margin:0;font-size:1rem;line-height:1.6}.print-step{page-break-inside:avoid;break-inside:avoid;border-bottom:1px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1.5rem}.print-step__header{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.print-step__number{color:#fff;background:var(--highlight-purple);border-radius:9999px;padding:.2rem .65rem;font-size:.75rem;font-weight:700;display:inline-block}.print-step__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8125rem;font-weight:600}.print-step__title{margin:0 0 1rem;font-size:1.25rem;font-weight:800;line-height:1.3}.print-step__explanation p{color:var(--text-primary);margin:0 0 .75rem;font-size:.9375rem;line-height:1.65}.print-step__tasks{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:1.25rem;padding:1rem 1.25rem}.print-step__tasks h3{margin:0 0 .75rem;font-size:.875rem;font-weight:700}.print-step__tasks ul{margin:0;padding:0;list-style:none}.print-step__tasks li{align-items:flex-start;gap:.65rem;margin-bottom:.5rem;font-size:.875rem;line-height:1.5;display:flex}.print-step__checkbox{border:2px solid #94a3b8;border-radius:3px;flex-shrink:0;width:1rem;height:1rem;margin-top:.15rem;display:inline-block}.print-step__save{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:10px;margin:1.25rem 0 0;padding:.75rem 1rem;font-size:.8125rem}.print-extension,.print-expert{border-top:2px dashed #cbd5e1;margin-top:2rem;padding-top:1.5rem}.print-extension h2,.print-expert h2{margin:0 0 1rem;font-size:1.25rem}.print-expert p{margin:0 0 .5rem;font-size:.9375rem;line-height:1.6}.print-expert__url{color:var(--text-muted);word-break:break-all;font-size:.8125rem}.print-sheet__footer{text-align:center;color:var(--text-muted);border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:1rem;font-size:.75rem}.print-sheet .scratchblocks-wrapper{page-break-inside:avoid;break-inside:avoid;max-width:100%;overflow:visible}@media print{@page{margin:1.2cm;size:A4}body{background:#fff!important}.no-print{display:none!important}.print-page{background:#fff;padding:0}.print-sheet{max-width:none;box-shadow:none;border-radius:0;margin:0;padding:0}.print-step{page-break-inside:avoid;break-inside:avoid}.glass-card,.dot-grid,.page,nav,.navbar{display:none!important}}:root{--background:#fafbff;--surface:#ffffffb8;--surface-solid:#fff;--surface-border:#ffffffe6;--text-primary:#0f0f0f;--text-secondary:#374151;--text-muted:#94a3b8;--highlight-purple:#8b5cf6;--highlight-blue:#3b82f6;--highlight-pink:#ec4899;--highlight-orange:#f97316;--blob-1:#8b5cf659;--blob-2:#3b82f647;--blob-3:#ec489938;--star-gold:#f59e0b;--card-shadow:0 8px 32px #0f172a0f;--card-shadow-hover:0 20px 50px #0f172a1f;--easy:#10b981;--easy-bg:#10b9811f;--medium:#f59e0b;--medium-bg:#f59e0b1f;--hard:#ef4444;--hard-bg:#ef44441f;--radius-lg:20px;--radius-xl:24px;--radius-full:9999px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--background);color:var(--text-primary);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,system-ui,sans-serif;line-height:1.6}h1,h2,h3,h4{letter-spacing:-.03em;font-family:Bricolage Grotesque,Syne,system-ui,sans-serif;font-weight:800;line-height:1.1}.font-display{font-family:Bricolage Grotesque,Syne,system-ui,sans-serif}.font-mono{font-family:JetBrains Mono,monospace}.page{min-height:100vh;position:relative;overflow-x:hidden}.page-inner{z-index:1;position:relative}.dot-grid{background-image:radial-gradient(circle,#0f172a0a 1px,#0000 1px);background-size:28px 28px}.glass-card{background:var(--surface);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);overflow-wrap:break-word;word-wrap:break-word;border:1px solid #ffffffd9;min-width:0;max-width:100%;overflow:hidden}.glass-card>*{min-width:0;max-width:100%}.card-meta{flex-wrap:wrap;align-items:center;gap:.5rem;min-width:0;max-width:100%;display:flex}.glass-card .btn-difficulty{box-sizing:border-box;max-width:100%}.glass-card-hover{transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s,border-color .3s}.glass-card-hover:hover{box-shadow:var(--card-shadow-hover);border-color:#8b5cf640;transform:translateY(-6px)}.highlight-pill{color:#fff;border-radius:.45em;padding:.08em .5em;display:inline-block;box-shadow:0 4px 14px #0000001f}.highlight-pill--purple{background:linear-gradient(135deg,#7c3aed,#a78bfa)}.highlight-pill--blue{background:linear-gradient(135deg,#2563eb,#60a5fa)}.highlight-pill--pink{background:linear-gradient(135deg,#db2777,#f472b6)}.btn{border-radius:var(--radius-full);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s,opacity .2s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#6366f1 50%,#8b5cf6 100%);padding:.875rem 2rem;box-shadow:0 4px 20px #7c3aed59}.btn-primary:hover{box-shadow:0 8px 28px #7c3aed73}.btn-ghost{color:var(--text-primary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb3;border:1.5px solid #0f172a14;padding:.875rem 2rem}.btn-ghost:hover{background:#fff;border-color:#0f172a1f}.btn-sm{min-height:44px;padding:.625rem 1.25rem;font-size:1rem}.btn-difficulty{color:#fff;text-align:center;border-radius:14px;width:100%;min-height:44px;padding:.875rem;font-size:1rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s}.btn-difficulty:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.blob{filter:blur(80px);will-change:transform;border-radius:50%;position:absolute}@keyframes blob-drift-1{0%,to{transform:translate(0)scale(1)}33%{transform:translate(40px,-30px)scale(1.08)}66%{transform:translate(-30px,20px)scale(.94)}}@keyframes blob-drift-2{0%,to{transform:translate(0)scale(1)}33%{transform:translate(-35px,25px)scale(1.1)}66%{transform:translate(20px,-30px)scale(.9)}}@keyframes blob-drift-3{0%,to{transform:translate(-50%)scale(1)}50%{transform:translate(calc(25px - 50%),-20px)scale(1.06)}}.blob-1{animation:26s ease-in-out infinite blob-drift-1}.blob-2{animation:30s ease-in-out infinite blob-drift-2}.blob-3{animation:24s ease-in-out infinite blob-drift-3}@keyframes card-enter{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.card-animate{opacity:0;animation:.5s cubic-bezier(.22,1,.36,1) forwards card-enter}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.float-slow{animation:5s ease-in-out infinite float}@keyframes tick-bounce{0%{transform:scale(0)}60%{transform:scale(1.3)}to{transform:scale(1)}}.tick-bounce{animation:.35s ease-out tick-bounce}@keyframes block-glow{0%{box-shadow:0 0 #8b5cf680}50%{box-shadow:0 0 0 10px #8b5cf626}to{box-shadow:0 0 #8b5cf600}}.block-glow{border-radius:10px;animation:1s ease-out block-glow}.filter-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-full);box-shadow:var(--card-shadow);background:#ffffffa6;border:1px solid #ffffffe6;flex-wrap:wrap;gap:.375rem;padding:.375rem;display:inline-flex}.filter-pill{border-radius:var(--radius-full);cursor:pointer;min-height:44px;color:var(--text-secondary);background:0 0;border:none;padding:.625rem 1.25rem;font-size:1rem;font-weight:600;transition:all .25s}.filter-pill:hover{color:var(--text-primary);background:#fffc}.filter-pill--active{color:#fff;box-shadow:0 4px 12px #0000001f}.badge{border-radius:var(--radius-full);align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge--easy{background:var(--easy-bg);color:#065f46}.badge--medium{background:var(--medium-bg);color:#92400e}.badge--hard{background:var(--hard-bg);color:#991b1b}.time-pill{border-radius:var(--radius-full);color:var(--text-secondary);background:#0f172a0d;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.75rem;font-weight:500;display:inline-flex}.stars{color:var(--star-gold);gap:1px;display:inline-flex}.star-icon{width:14px;height:14px}.progress-track{border-radius:var(--radius-full);background:#0f172a0f;height:8px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);background:linear-gradient(90deg,#7c3aed,#8b5cf6,#a78bfa);height:100%;transition:width .5s cubic-bezier(.22,1,.36,1)}pre.blocks,code.b{font-family:JetBrains Mono,monospace}pre.blocks{background:#ffffff80;border:1px solid #0f172a0f;border-radius:14px;margin:1.25rem 0;padding:1rem 1.25rem;overflow-x:auto}.scratchblocks-wrapper{-webkit-overflow-scrolling:touch;background:#fff6;border-radius:14px;max-width:100%;margin:1.5rem 0;padding:.5rem;overflow-x:auto}.scratchblocks-wrapper .scratchblocks{max-width:none;display:inline-block}.scratchblocks-wrapper svg{max-width:none;height:auto}.block-inline{vertical-align:middle;cursor:pointer;border-radius:6px;transition:transform .15s;display:inline-block}.block-inline:hover{transform:scale(1.03)}.section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--highlight-purple);margin-bottom:.75rem;font-size:.8125rem;font-weight:700;display:inline-block}.cta-band{border-radius:var(--radius-xl);overflow-wrap:break-word;background:linear-gradient(135deg,#7c3aed0f 0%,#3b82f60f 50%,#ec48990a 100%);border:1px solid #8b5cf61f;min-width:0;max-width:100%;overflow:hidden}a:focus-visible,button:focus-visible,[role=checkbox]:focus-visible{outline-offset:2px;outline:2px solid #8b5cf6}.skip-link{z-index:100;color:#fff;background:#7c3aed;border-radius:.5rem;padding:.75rem 1.25rem;font-size:1rem;font-weight:600;text-decoration:none;position:absolute;top:-100%;left:1rem}.skip-link:focus{top:1rem}.tutorial-body{font-size:1.125rem;line-height:1.7}.tutorial-body p{margin-bottom:1rem}.tutorial-meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:1rem;font-weight:600}.tutorial-you-should-see{color:var(--text-primary);background:#ede9fe99;border:1px solid #7c3aed33;border-radius:1rem;margin-top:1.5rem;padding:1rem 1.25rem;font-size:1.125rem;line-height:1.6}.tutorial-you-should-see strong{color:#6d28d9}.step-content__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.step-content__header h2{flex:1;min-width:0;margin:0}.btn-open-scratch{border-radius:var(--radius-full);color:#fff;background:linear-gradient(135deg,#4c97ff,#3373cc);flex-shrink:0;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.625rem 1.25rem;font-size:1rem;font-weight:700;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 4px 16px #4c97ff66}.btn-open-scratch:hover{transform:translateY(-1px);box-shadow:0 6px 20px #4c97ff80}.scratch-ui-guide{background:#4c97ff0f;border:2px dashed #4c97ff59;border-radius:1rem;margin-bottom:2rem;padding:1.25rem}.scratch-ui-guide__title{margin:0 0 .5rem;font-size:1.25rem}.scratch-ui-guide__intro{color:var(--text-secondary);margin:0 0 1.25rem;font-size:1rem}.scratch-ui-guide__grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=640px){.scratch-ui-guide__grid{grid-template-columns:repeat(2,1fr)}}.scratch-ui-guide__item{margin:0}.scratch-ui-guide__placeholder{text-align:center;background:#ffffffb3;border:2px dashed #94a3b8;border-radius:.75rem;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;min-height:120px;padding:1rem;display:flex}.scratch-ui-guide__placeholder-label{text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-size:.75rem;font-weight:700}.scratch-ui-guide__placeholder-title{color:#4c97ff;font-size:1.125rem;font-weight:700}.scratch-ui-guide__item figcaption{color:var(--text-secondary);text-align:center;margin-top:.5rem;font-size:1rem;font-weight:600}.step-pill__time{background:#ffffff40;border-radius:9999px;margin-left:.25rem;padding:.125rem .5rem;font-size:.8125rem;font-weight:500;display:inline-block}.step-pill--active .step-pill__time{background:#fff3}.step-pill:not(.step-pill--active) .step-pill__time{color:var(--text-secondary);background:#0f172a0f}.card-progress-badge{color:#fff;z-index:2;background:#059669;border-radius:9999px;padding:.375rem .75rem;font-size:.875rem;font-weight:700;position:absolute;top:1rem;right:1rem;box-shadow:0 2px 8px #05966959}.card-progress-badge--done{background:#047857}.tutorial-card{position:relative}.step-toast{z-index:60;color:#fff;opacity:0;pointer-events:none;background:linear-gradient(135deg,#7c3aed,#6366f1);border-radius:9999px;padding:1rem 2rem;font-size:1.125rem;font-weight:700;transition:opacity .4s,transform .4s;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)translateY(1rem);box-shadow:0 8px 32px #7c3aed66}.step-toast--visible{opacity:1;transform:translate(-50%)translateY(0)}.tutorial-complete{text-align:center;margin-top:2rem;padding:2.5rem 2rem}.tutorial-complete__emoji{margin:0 0 1rem;font-size:3rem}.tutorial-complete__title{margin:0 0 1rem;font-size:2rem}.tutorial-complete__text{color:var(--text-secondary);margin:0 0 1.5rem;font-size:1.125rem;line-height:1.7}.navbar__links{align-items:center;gap:.75rem;display:flex}.navbar__link{border-radius:var(--radius-full);min-width:44px;min-height:44px;color:var(--text-primary);justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.9375rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex}.navbar__link:hover{background:#0f172a0f}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.blob-1,.blob-2,.blob-3{animation:none}.float-slow,.tick-bounce,.card-animate,.glass-card-hover,.step-toast{transition:none;animation:none}.glass-card-hover:hover,.btn:hover,.btn-open-scratch:hover{transform:none}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
