/*! 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-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--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;--tw-ease:initial;--tw-font-weight: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-blue-500:oklch(62.3% .214 259.815);--spacing:.25rem;--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-bold:700;--ease-out:cubic-bezier(0, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--animate-float:float 5s ease-in-out infinite}}@layer base{@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)}}}*,: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{@media (hover:hover){.hover\:underline:hover{text-decoration-line:underline}}.mt-2\!{margin-top:calc(var(--spacing) * 2)!important}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6\!{margin-bottom:calc(var(--spacing) * 6)!important}.block{display:block}.flex{display:flex}.grid{display:grid}.h-screen{height:100vh}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-float{animation:var(--animate-float)}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.overflow-hidden{overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-\[color-mix\(in_srgb\,\#3B82F6_10\%\,white\)\]{--tw-gradient-from:#ebf3fe;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[color-mix\(in_srgb\,\#23F0C7_10\%\,white\)\]{--tw-gradient-from:#e9fef9;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[color-mix\(in_srgb\,\#B088F9_10\%\,white\)\]{--tw-gradient-from:#f7f3fe;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[color-mix\(in_srgb\,\#FF6B6B_10\%\,white\)\]{--tw-gradient-from:#fff0f0;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[color-mix\(in_srgb\,\#FF90E8_10\%\,white\)\]{--tw-gradient-from:#fff4fd;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[color-mix\(in_srgb\,\#FFD000_10\%\,white\)\]{--tw-gradient-from:#fffae6;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.via-\[\#4ECDC4\]\/15{--tw-gradient-via:oklab(77.6198% -.110362 -.0165652/.15);--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.via-\[\#FF90E8\]\/15{--tw-gradient-via:oklab(79.9248% .15412 -.0711198/.15);--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.via-\[\#FFD000\]\/15{--tw-gradient-via:oklab(87.3003% -.00693905 .178478/.15);--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.via-\[\#FFE66D\]\/15{--tw-gradient-via:oklab(92.2351% -.0193175 .141431/.15);--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-\[\#3B82F6\]\/10{--tw-gradient-to:oklab(62.3083% -.0332476 -.185052/.1);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#23F0C7\]\/10{--tw-gradient-to:oklab(85.4281% -.157157 .0168451/.1);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#B088F9\]\/10{--tw-gradient-to:oklab(71.1309% .077947 -.143602/.1);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#FF6B6B\]\/10{--tw-gradient-to:oklab(71.1607% .167013 .0703394/.1);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#FF90E8\]\/10{--tw-gradient-to:oklab(79.9248% .15412 -.0711198/.1);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#FFD000\]\/10{--tw-gradient-to:oklab(87.3003% -.00693905 .178478/.1);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.pt-0\!{padding-top:calc(var(--spacing) * 0)!important}.pr-0\!{padding-right:calc(var(--spacing) * 0)!important}.pb-8\!{padding-bottom:calc(var(--spacing) * 8)!important}.pl-0\!{padding-left:calc(var(--spacing) * 0)!important}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-blue-500{color:var(--color-blue-500)}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px 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)}.blur{--tw-blur:blur(8px);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,)}.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,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.\[al\:剑来\]{al:剑来}.\[al\:平凡之路\]{al:平凡之路}.\[al\:年少心动雨季\]{al:年少心动雨季}.\[al\:橙\]{al:橙}.\[ar\:朴树\]{ar:朴树}.\[ar\:江肆\]{ar:江肆}.\[ar\:知更鸟\/HOYO-MiX\/Chevy\]{ar:知更鸟/HOYO-MiX/Chevy}.\[ar\:雷雨心\]{ar:雷雨心}.\[ar\:鹿晗\]{ar:鹿晗}.\[ar\:黄霄雲\]{ar:黄霄雲}.\[offset\:0\]{offset:0}.\[ti\:年少心动雨季\]{ti:年少心动雨季}.\[ti\:知我\]{ti:知我}.\[ti\:记念\]{ti:记念}.\[ti\:鹿晗-我们的明天\]{ti:鹿晗-我们的明天}@media (hover:hover){.hover\:underline:hover{text-decoration-line:underline}}}.signature-input-body{opacity:1;flex-direction:column;align-items:center;gap:10px;width:100%;max-height:400px;transition:max-height .35s,opacity .25s,margin .3s;display:flex}.signature-input-body.collapsed{opacity:0;pointer-events:none;gap:0;max-height:0;margin:0}.signature-page{isolation:isolate;background:radial-gradient(circle at 9% 15%,#ff4fd86b 0 10%,#0000 11%),radial-gradient(circle at 86% 18%,#ffe74c7a 0 9%,#0000 10%),radial-gradient(circle at 75% 82%,#2df7b56b 0 12%,#0000 13%),repeating-linear-gradient(112deg,#0000 0 30px,#1515150b 31px 34px),linear-gradient(135deg,#b2fffc 0%,#fff0fb 48%,#fff7bd 100%);flex-direction:column;align-items:stretch;min-height:100vh;padding:20px 20px 0;display:flex;position:relative;overflow:hidden}.signature-page:before{content:"";z-index:0;pointer-events:none;opacity:.26;background-image:radial-gradient(circle,#15151529 0 2px,#0000 2.4px),linear-gradient(45deg,#0000 42%,#ff595e29 43% 48%,#0000 49%);background-position:10px 14px,36px 44px;background-size:34px 34px,126px 126px;position:absolute;inset:0}.sig-bg-container{z-index:0;pointer-events:none;font-family:yinhenailaoanlianti,STXingkai,FZShuTi,LiSu,KaiTi,Microsoft YaHei,serif;position:absolute;inset:0;overflow:hidden}.sig-bg-blessing{white-space:nowrap;-webkit-user-select:none;user-select:none;text-shadow:1px 1px #ffffff6b,2px 2px #1515150f;line-height:1;position:absolute}.sig-bg-constellation{filter:drop-shadow(0 0 4px #ffffff7a);position:absolute;overflow:visible}.signature-blessing-bg{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.blessing-text{color:#15151514;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;font-family:yinhenailaoanlianti,serif;font-weight:800;position:absolute}.blessing-1{font-size:48px;top:8%;left:5%;transform:rotate(-15deg)}.blessing-2{font-size:56px;top:15%;right:8%;transform:rotate(10deg)}.blessing-3{font-size:42px;top:28%;left:12%;transform:rotate(-8deg)}.blessing-4{font-size:52px;top:35%;right:15%;transform:rotate(12deg)}.blessing-5{font-size:38px;top:48%;left:3%;transform:rotate(-20deg)}.blessing-6{font-size:46px;top:55%;right:5%;transform:rotate(5deg)}.blessing-7{font-size:50px;top:68%;left:18%;transform:rotate(-12deg)}.blessing-8{font-size:44px;top:75%;right:12%;transform:rotate(18deg)}.blessing-9{font-size:40px;top:85%;left:8%;transform:rotate(-5deg)}.blessing-10{font-size:54px;top:92%;right:20%;transform:rotate(8deg)}.signature-page-title{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height));--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold);color:#151515;opacity:1;letter-spacing:0;text-align:center;text-shadow:3px 3px #ff4fd8,6px 6px #ffe74c;z-index:1;margin-bottom:15px;font-weight:900;position:relative}.signatures-display-area{z-index:1;background:0 0;border:none;border-radius:12px;grid-template-columns:repeat(9,1fr);align-items:start;gap:8px;width:100%;padding:0 20px 320px;display:grid;position:relative;overflow-y:auto}.signatures-empty-hint{color:#51334b;opacity:.78;grid-column:1/-1;justify-content:center;align-items:center;padding:30px 0;font-size:14px;display:flex}.signature-cell{background:repeating-linear-gradient(-12deg,#0000 0 12px,#ffe74c38 13px 15px),#fff;border:3px solid #151515;border-radius:14px 4px 14px 5px;width:100%;padding-bottom:65%;position:relative;overflow:hidden;box-shadow:3px 3px #151515}.signature-thumbnail{object-fit:contain;border:2px dashed #15151538;border-radius:8px 3px;width:calc(100% - 8px);height:calc(100% - 8px);position:absolute;inset:4px}.signature-fixed-bottom{z-index:100;background:radial-gradient(circle at 94% 12%,#ff4fd84d 0 24px,#0000 25px),repeating-linear-gradient(90deg,#0000 0 28px,#25d9ff14 29px 32px),#fff;border:4px solid #151515;border-radius:24px 6px 22px 7px;flex-direction:column;align-items:center;gap:12px;width:80%;max-width:600px;padding:16px 20px 20px;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:8px 8px #151515,13px 13px #ffe74cb8}.signature-hint-row{justify-content:space-between;align-items:center;width:100%;display:flex}.signature-hint-text{color:#151515;opacity:.76;font-size:13px;font-weight:800}.signature-count{color:#151515;opacity:.76;font-size:12px;font-weight:800}.signature-canvas-area{align-items:center;gap:16px;width:100%;display:flex}.signature-color-column{flex-direction:column;flex-shrink:0;gap:8px;display:flex}.signature-color-btn{cursor:pointer;border:3px solid #151515;border-radius:50%;width:28px;height:28px;transition:all .15s;box-shadow:3px 3px #151515}.signature-color-btn:hover{transform:scale(1.15);box-shadow:4px 4px #151515}.signature-color-btn.active{border-color:#151515;transform:scale(1.1);box-shadow:0 0 0 2px #fff,0 0 0 5px #151515}.signature-canvas-wrapper{flex:1;justify-content:center;display:flex}.signature-canvas{cursor:crosshair;touch-action:none;background:repeating-linear-gradient(0deg,#0000 0 26px,#15151509 27px 29px),#fff;border:3px dashed #151515;border-radius:16px 5px 16px 6px;width:100%}.signature-buttons{gap:10px;display:flex}.signature-btn{cursor:pointer;border:3px solid #151515;border-radius:18px 5px 16px 6px;padding:10px 24px;font-size:14px;font-weight:800;transition:all .15s;box-shadow:4px 4px #151515}.signature-btn:hover{transform:translate(2px,2px);box-shadow:2px 2px #151515}.signature-btn:active{box-shadow:none;transform:translate(4px,4px)}.signature-btn-clear{color:#151515;background:#ffe74c}.signature-btn-confirm{color:#151515;background:#ff4fd8}.signature-btn-done{color:#151515;background:#2df7b5}.signature-btn-done:hover:not(.disabled){background:#25d9ff}.signature-btn-done.disabled{color:#999;cursor:not-allowed;pointer-events:none;opacity:.5;box-shadow:none;background:#ddd}.signature-floating{pointer-events:none;box-shadow:0 4px 20px #1f252326}.signature-toggle-btn{cursor:pointer;background:#ffe74c;border:3px solid #151515;border-radius:12px 4px;padding:4px 12px;font-size:12px;font-weight:800;transition:all .15s;box-shadow:3px 3px #151515}.signature-toggle-btn:hover{transform:translate(1px,1px);box-shadow:2px 2px #151515}.signature-toggle-btn:active{box-shadow:none;transform:translate(2px,2px)}.signature-hint-right{align-items:center;gap:12px;display:flex}.signature-fixed-bottom.collapsed{padding:12px 20px}.signature-fixed-bottom.collapsed .signature-hint-row{margin-bottom:0}.signature-cell{cursor:pointer;transition:all .2s}.signature-cell:hover{transform:scale(1.05)rotate(-1deg);box-shadow:4px 4px #151515,7px 7px #ff4fd8}.signature-cell:hover:after{content:"双击删除";color:#ffe74c;pointer-events:none;background:#151515;border-radius:4px;padding:2px 6px;font-size:10px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.signature-capture-heading{z-index:1;color:#151515;text-align:center;margin:10px 0 28px;font-family:yinhenailaoanlianti,serif;position:relative}.signature-capture-heading h1{letter-spacing:0;text-shadow:3px 3px #ff4fd8,6px 6px #ffe74c;margin:0 0 10px;font-size:52px;font-weight:900;line-height:1.15}.signature-capture-heading p{color:#555;margin:0 0 6px;font-size:36px;font-weight:800;line-height:1.12}.signature-capture-heading p+p{font-size:32px}.signature-capture-heading time{color:#777;font-size:22px;font-weight:800;line-height:1.2;display:block}.signature-capture-mode{overflow:auto}.signature-capture-mode .signatures-display-area{padding-bottom:40px;overflow:visible}.signature-capture-mode .signature-fixed-bottom{display:none}.signature-capture-mode .signature-cell{transition:none}.signature-capture-mode .signature-cell:hover{transform:none;box-shadow:3px 3px #151515}.signature-capture-mode .signature-cell:hover:after{content:none}.signature-test-page{color:#151515;background:radial-gradient(circle at 12% 14%,#2df7b557 0 9%,#0000 10%),radial-gradient(circle at 88% 18%,#ffe74c70 0 8%,#0000 9%),radial-gradient(circle at 76% 86%,#ff4fd84d 0 10%,#0000 11%),linear-gradient(135deg,#e6fffb 0%,#fff7bd 48%,#fff0fb 100%);min-height:100vh;padding:24px}.signature-test-header{justify-content:space-between;align-items:end;gap:16px;max-width:1280px;margin:0 auto 20px;display:flex}.signature-test-header p{color:#34495e;text-transform:uppercase;margin:0;font-size:13px;font-weight:900}.signature-test-header h1{letter-spacing:0;margin:0;font-size:30px;font-weight:900}.signature-test-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;max-width:1280px;margin:0 auto;display:grid}.signature-test-panel{background:#ffffffeb;border:3px solid #151515;border-radius:8px;flex-direction:column;gap:14px;min-height:620px;padding:18px;display:flex;box-shadow:6px 6px #151515}.signature-test-panel-header{justify-content:space-between;align-items:start;gap:14px;min-height:72px;display:flex}.signature-test-panel-kicker{color:#e91e63;margin:0 0 6px;font-size:15px;font-weight:900}.signature-test-panel h2{color:#151515;margin:0;font-size:18px;font-weight:900;line-height:1.25}.signature-test-select,.signature-test-clear{color:#151515;cursor:pointer;border:3px solid #151515;border-radius:6px;flex:none;min-height:40px;padding:8px 14px;font-size:13px;font-weight:900;box-shadow:3px 3px #151515}.signature-test-select{background:#ffe74c}.signature-test-select.active{background:#2df7b5}.signature-test-clear{background:#ff4fd8;align-self:flex-start}.signature-test-canvas{cursor:crosshair;background:repeating-linear-gradient(0deg,#0000 0 28px,#1515150a 29px 31px),#fff;border:3px dashed #151515;border-radius:8px;flex:1;width:100%;min-height:460px}@media (width<=900px){.signature-test-grid{grid-template-columns:1fr}.signature-test-panel{min-height:440px}.signature-test-canvas{min-height:300px}}@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-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@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}@property --tw-ease{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}.timeline-page{z-index:1;color:#151515;isolation:isolate;background:radial-gradient(circle at 12% 10%,#ff4fd86b 0 10%,#0000 11%),radial-gradient(circle at 88% 12%,#25d9ff61 0 9%,#0000 10%),radial-gradient(circle at 78% 78%,#2df7b557 0 11%,#0000 12%),repeating-linear-gradient(112deg,#0000 0 30px,#1515150b 31px 34px),linear-gradient(135deg,#fff7df 0%,#fff0fb 36%,#eafff8 70%,#fff7bd 100%);min-height:100vh;padding:clamp(60px,10vw,120px) clamp(24px,5vw,80px);position:relative;overflow:hidden}.timeline-page:before{content:"";z-index:0;pointer-events:none;opacity:.28;background-image:radial-gradient(circle,#15151529 0 2px,#0000 2.4px),linear-gradient(45deg,#0000 42%,#ff595e2e 43% 48%,#0000 49%);background-position:8px 12px,24px 42px;background-size:34px 34px,118px 118px;position:absolute;inset:0}.timeline-header{z-index:1;text-align:center;margin-bottom:clamp(60px,10vw,120px);position:relative}.timeline-subtitle{color:#151515;letter-spacing:.3em;background:#2df7b5;border:3px solid #151515;border-radius:18px 5px 16px 6px;margin:0 0 16px;padding:6px 18px;font-size:clamp(14px,1.5vw,18px);font-weight:700;display:inline-block;transform:rotate(-2deg);box-shadow:4px 4px #151515}.timeline-title{color:#151515;text-shadow:4px 4px #ff4fd8,8px 8px #ffe74c;margin:0;font-size:clamp(48px,8vw,96px);font-weight:900;line-height:1.1}.timeline-desc{color:#51334b;letter-spacing:.1em;margin:20px 0 0;font-size:clamp(20px,3vw,32px)}.timeline-timeline{z-index:1;max-width:1400px;margin:0 auto;padding:40px 0;position:relative}.timeline-timeline-line{background:linear-gradient(#0000,#ff4fd8 20%,#ffe74c 42%,#25d9ff 64%,#2df7b5 84%,#0000);border-radius:999px;width:6px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);box-shadow:3px 0 #151515}.timeline-timeline-item{width:fit-content;max-width:50%;padding:0 40px 60px;position:relative}.timeline-timeline-item.left{text-align:right;justify-content:flex-end;padding-right:70px;display:flex;left:0}.timeline-timeline-item.right{text-align:left;padding-left:60px;left:50%}.timeline-timeline-dot{z-index:2;background:#ffe74c;border:4px solid #151515;border-radius:50%;width:22px;height:22px;position:absolute;top:20px;box-shadow:3px 3px #151515}.timeline-timeline-item.left .timeline-timeline-dot{right:-11px}.timeline-timeline-item.right .timeline-timeline-dot{left:-11px}.timeline-timeline-dot span{background:#ff4fd8;border:2px solid #151515;border-radius:50%;width:8px;height:8px;margin:3px;display:block}.timeline-timeline-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:fit-content;transform:rotate(var(--timeline-tilt,-.8deg));background:radial-gradient(circle at 94% 8%,#ff4fd847 0 24px,#0000 25px),repeating-linear-gradient(-10deg,#0000 0 24px,#15151509 25px 27px),#fff;border:5px solid #151515;border-radius:22px 6px 20px 7px;overflow:hidden;box-shadow:9px 9px #151515,14px 14px #25d9ff8c}.timeline-timeline-item.right .timeline-timeline-content{--timeline-tilt:.8deg}.timeline-timeline-image-wrapper{background:linear-gradient(135deg,#ffffff80,#ffffff4d);width:630px;min-width:280px;max-width:100%;overflow:hidden}.timeline-timeline-image{object-fit:contain;width:auto;max-width:100%;height:auto;transition:transform .4s}.timeline-timeline-content:hover .timeline-timeline-image{transform:scale(1.04)rotate(-1deg)}.timeline-timeline-placeholder{color:#a09a94;background:linear-gradient(135deg,#ffffffc2,#ffffff4d),repeating-linear-gradient(-45deg,#c8c3bc26 0 12px,#ffffff80 12px 24px);justify-content:center;align-items:center;width:100%;height:100%;font-size:16px;font-weight:600;display:flex}.timeline-timeline-text{padding:20px 24px}.timeline-timeline-date{color:#151515;letter-spacing:.05em;background:#ffe74c;border:2px solid #151515;border-radius:12px 3px 12px 4px;padding:4px 10px;font-family:DM Mono,Courier New,monospace;font-size:clamp(12px,1.2vw,14px);display:inline-block;box-shadow:2px 2px #151515}.timeline-timeline-title{color:#151515;margin:8px 0;font-size:clamp(18px,2vw,24px);font-weight:700}.timeline-timeline-desc{color:#3e3941;margin:0;font-size:clamp(14px,1.3vw,16px);line-height:1.7}.timeline-footer{z-index:1;text-align:center;margin-top:clamp(80px,12vw,160px);padding-bottom:60px;position:relative}.timeline-quote{color:#55344b;letter-spacing:.05em;margin:0 0 40px;font-size:clamp(18px,2.5vw,28px);font-style:italic}.timeline-back{color:#151515;letter-spacing:.1em;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(90deg,#ff4fd8,#ffe74c 48%,#2df7b5),#fff;border:4px solid #151515;border-radius:20px 5px 18px 6px;padding:14px 36px;font-size:15px;font-weight:900;text-decoration:none;transition:all .15s;display:inline-block;box-shadow:6px 6px #151515}.timeline-back:hover{transform:translate(2px,2px);box-shadow:3px 3px #151515}.timeline-doodle{pointer-events:none;filter:drop-shadow(5px 5px #151515);z-index:0;opacity:.92;position:absolute}.timeline-doodle path,.timeline-doodle polygon{stroke:#1a1a1a;stroke-width:4px;stroke-linejoin:round;stroke-linecap:round}@keyframes doodle-float{0%{transform:translateY(0)rotate(0)}50%{transform:translateY(-12px)rotate(3deg)}to{transform:translateY(0)rotate(0)}}#timeline-doodle-heart{fill:#ff4fd8;width:clamp(100px,15vw,180px);animation:6s ease-in-out infinite doodle-float;top:8%;left:10%}#timeline-doodle-cloud{fill:#25d9ff;width:clamp(120px,18vw,220px);animation:7s ease-in-out .5s infinite doodle-float;top:55%;left:3%}#timeline-doodle-star{fill:#ffe74c;width:clamp(90px,13vw,160px);animation:5s ease-in-out 1s infinite doodle-float;top:4%;right:8%}#timeline-doodle-lightning{fill:#ff595e;width:clamp(80px,12vw,140px);animation:8s ease-in-out 1.5s infinite doodle-float;top:38%;right:4%}#timeline-doodle-spiral{fill:none;stroke:#9b5cff;width:clamp(70px,10vw,110px);animation:6s ease-in-out 2s infinite doodle-float;top:78%;right:18%}#timeline-doodle-blob{fill:#2df7b5;opacity:.85;width:clamp(100px,14vw,160px);animation:7s ease-in-out 2.5s infinite doodle-float;top:22%;left:48%}@media (width<=768px){.timeline-doodle{opacity:.32}#timeline-doodle-blob,#timeline-doodle-spiral{display:none}}@font-face{font-family:HYShangWeiShouShu;src:url(/fonts/8841c4b5366dbc90ce72a6e711bbdf35.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:yinhenailaoanlianti;src:url(/fonts/yinhenailaoanlianti.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}:root{--ink:#151515;--paper:#fff7df;--pop-pink:#ff4fd8;--pop-red:#ff595e;--pop-yellow:#ffe74c;--pop-green:#2df7b5;--pop-cyan:#25d9ff;--pop-blue:#3b82f6;--pop-purple:#9b5cff;--doodle-shadow:6px 6px 0 var(--ink);--doodle-shadow-small:3px 3px 0 var(--ink);color:var(--ink);background:var(--paper);font-synthesis:none;text-rendering:optimizelegibility;font-family:yinhenailaoanlianti,Noto Sans SC,DM Mono,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-shell{isolation:isolate;background:radial-gradient(circle at 12% 18%,#ff4fd847 0 8%,#0000 9%),radial-gradient(circle at 87% 16%,#25d9ff3d 0 7%,#0000 8%),radial-gradient(circle at 78% 82%,#2df7b53d 0 9%,#0000 10%),linear-gradient(135deg,#fff7df 0%,#fff1f8 35%,#e9fff9 68%,#fff7c7 100%);min-height:100vh;position:relative;overflow:hidden}.app-shell:before{content:"";z-index:0;background:radial-gradient(circle at 8% 22%, var(--accent,#ff4fd8) 0 10px, transparent 11px), radial-gradient(circle at 18% 84%, var(--secondary,#25d9ff) 0 8px, transparent 9px), radial-gradient(circle at 78% 28%, #ffe74c80 0 12px, transparent 13px), radial-gradient(circle at 92% 72%, #2df7b56b 0 10px, transparent 11px), repeating-linear-gradient(12deg, transparent 0 26px, #15151509 27px 29px), repeating-linear-gradient(96deg, transparent 0 34px, #ff4fd814 35px 38px);position:fixed;inset:0}@supports (color:color-mix(in lab, red, red)){.app-shell:before{background:radial-gradient(circle at 8% 22%, color-mix(in srgb, var(--accent,#ff4fd8), transparent 36%) 0 10px, transparent 11px), radial-gradient(circle at 18% 84%, color-mix(in srgb, var(--secondary,#25d9ff), transparent 40%) 0 8px, transparent 9px), radial-gradient(circle at 78% 28%, #ffe74c80 0 12px, transparent 13px), radial-gradient(circle at 92% 72%, #2df7b56b 0 10px, transparent 11px), repeating-linear-gradient(12deg, transparent 0 26px, #15151509 27px 29px), repeating-linear-gradient(96deg, transparent 0 34px, #ff4fd814 35px 38px)}}.app-shell:before{opacity:.88;mix-blend-mode:multiply;pointer-events:none}.app-shell:after{content:"";z-index:0;opacity:.22;pointer-events:none;background-image:linear-gradient(45deg,#0000 42%,#15151517 43% 47%,#0000 48%),radial-gradient(circle,#15151524 0 2px,#0000 2.4px),linear-gradient(135deg,#ff595e26 0 12px,#0000 12px 100%);background-position:0 0,12px 18px,38px 24px;background-size:92px 92px,34px 34px,148px 148px;position:fixed;inset:0}.topbar{z-index:20;border-bottom:4px solid var(--ink);box-shadow:0 5px 0 var(--ink);background:linear-gradient(90deg,#ffe74cdb,#ff4fd82e,#25d9ff5c),#fffdf2;justify-content:space-between;align-items:center;gap:22px;padding:18px clamp(18px,4vw,54px);display:flex;position:sticky;top:0}.brand{white-space:nowrap;align-items:baseline;gap:10px;display:flex}.brand span{border:3px solid var(--ink);letter-spacing:0;color:var(--ink);background:var(--pop-yellow);box-shadow:var(--doodle-shadow-small);border-radius:18px 5px 16px 6px;padding:6px 12px;font-size:13px;font-weight:700;transform:rotate(-1deg)}.brand strong{color:#1a1a1a;font-size:20px;font-weight:900}.teacher-tabs{gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.teacher-tabs button{border:3px solid var(--ink);min-height:38px;color:var(--ink);box-shadow:var(--doodle-shadow-small);cursor:pointer;background:#fff;border-radius:18px 5px 16px 6px;flex:none;padding:0 18px;font-weight:700;transition:all .15s}.teacher-tabs button:hover{background:var(--tab,#ff6b6b);color:#fff;box-shadow:2px 2px 0 var(--ink);transform:translate(2px,2px)}.teacher-tabs button.active{color:#fff;background:var(--tab);border-color:#000;transform:translateY(-2px);box-shadow:4px 4px #000}.teacher-tabs button.home.active{color:#fff;background:#ff6b6b;border-color:#000;box-shadow:4px 4px #000}.teacher-tabs .tab-btn{border:3px solid var(--ink);cursor:pointer;color:var(--ink);z-index:0;box-shadow:var(--doodle-shadow-small);background:#fff;border-radius:18px 5px 16px 6px;justify-content:center;align-items:center;padding:10px 22px;font-weight:800;transition:all .15s;display:inline-flex;position:relative;overflow:hidden}.teacher-tabs .tab-btn:hover{background:var(--tab);color:#fff;transform:translate(2px,2px);box-shadow:2px 2px #000}.teacher-tabs .tab-btn:active{box-shadow:none;transform:translate(4px,4px)}.teacher-tabs .tab-btn .hoverEffect{z-index:1;opacity:0;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.teacher-tabs .tab-btn:hover .hoverEffect{opacity:1}.teacher-tabs .tab-btn .hoverEffect div{background:var(--tab-gradient,linear-gradient(90deg, #c94d45 0%, #e8836a 49%, #ffc7bb 100%));filter:blur(16px);opacity:.5;border-radius:40rem;width:6rem;height:6rem;transition:all .4s;animation:3s linear infinite effect}.teacher-tabs .tab-btn:hover .hoverEffect div{width:5rem;height:5rem}.teacher-tabs .tab-btn.active{color:#fff;background:var(--tab);border-color:#000;transform:translateY(-2px);box-shadow:4px 4px #000}.teacher-tabs .tab-btn.active .hoverEffect{opacity:1}.selector-page{z-index:1;flex-direction:column;justify-content:space-between;height:100vh;padding:clamp(70px,10vw,130px) clamp(24px,5vw,70px) clamp(20px,4vw,50px);display:flex;position:relative;overflow:hidden}.watermark-banner{text-align:center;letter-spacing:.5em;color:var(--pop-pink);opacity:0;pointer-events:none;text-shadow:3px 3px 0 var(--pop-yellow), -2px -2px 0 #fff, 5px 5px 0 var(--ink);font-size:clamp(1.8rem,4.5vw,3.5rem);font-weight:900;animation:1s forwards fadeInSimple;position:absolute;top:clamp(36px,6vw,80px);left:0;right:0}.selector-heading{max-width:880px}.time-marker{color:#6f3d65;opacity:0;margin-top:20px;font-size:clamp(.95rem,1.2vw,1.1rem);animation:1s forwards fadeInSimple}.selector-heading h1{color:var(--ink);opacity:0;margin-top:6px;font-size:clamp(40px,7vw,80px);line-height:1;animation:1.2s cubic-bezier(.23,1,.32,1) .3s forwards titleSlideUp}.class-header{color:#1f2523;letter-spacing:.08em;opacity:0;font-family:Noto Serif SC,serif;font-size:clamp(18px,2.5vw,28px);font-weight:700;animation:1s .15s forwards fadeInSimple}.guide-text{color:#3f3a43;opacity:0;max-width:520px;margin-top:14px;font-size:clamp(16px,1.5vw,20px);line-height:1.9;animation:.8s .6s forwards fadeInSimple}.guide-text-2{margin-top:0;animation-delay:.75s}.selector-transition{color:#71425f;opacity:0;margin-top:14px;font-size:clamp(1rem,1.2vw,1.15rem);animation:.6s .8s forwards fadeInSimple}.subject-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(14px,2vw,22px);margin-top:clamp(20px,3vw,36px);display:grid}.subject-card{text-align:left;min-height:180px;color:var(--ink);background:radial-gradient(circle at 86% 16%, var(--secondary) 0 22px, transparent 23px), radial-gradient(circle at 14% 85%, var(--accent) 0 18px, transparent 19px), repeating-linear-gradient(-12deg, transparent 0 20px, #1515150a 21px 23px), linear-gradient(145deg, #fff 0 42%, var(--secondary) 100%);border-radius:24px 7px 22px 6px;padding:28px;text-decoration:none;display:block;position:relative;overflow:hidden}@supports (color:color-mix(in lab, red, red)){.subject-card{background:radial-gradient(circle at 86% 16%, color-mix(in srgb, var(--secondary), #fff 8%) 0 22px, transparent 23px), radial-gradient(circle at 14% 85%, color-mix(in srgb, var(--accent), #fff 20%) 0 18px, transparent 19px), repeating-linear-gradient(-12deg, transparent 0 20px, #1515150a 21px 23px), linear-gradient(145deg, #fff 0 42%, color-mix(in srgb, var(--secondary), #fff 35%) 100%)}}.subject-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:4px solid var(--ink);box-shadow:var(--doodle-shadow);cursor:pointer;opacity:0;transition:all .15s;transform:translateY(30px)}.subject-card:after{content:"";border:3px solid var(--ink);background:var(--accent);border-radius:48% 52% 42% 58%;width:142px;height:102px;position:absolute;bottom:-30px;right:-24px}@supports (color:color-mix(in lab, red, red)){.subject-card:after{background:color-mix(in srgb, var(--accent), #fff 10%)}}.subject-card:after{opacity:.34;transition:opacity .3s;transform:rotate(-12deg)}.subject-card:before{content:"";border:3px solid var(--ink);background:linear-gradient(90deg, transparent 44%, var(--ink) 45% 55%, transparent 56%), var(--pop-yellow);opacity:.85;border-radius:50%;width:54px;height:24px;transition:opacity .3s;position:absolute;top:16px;left:auto;right:18px;transform:rotate(18deg)}.subject-card.card-visible{opacity:1;transition:opacity 1.2s cubic-bezier(.23,1,.32,1),transform 1.2s cubic-bezier(.23,1,.32,1),box-shadow .3s;transform:translateY(0)}@media (hover:hover){.subject-card:hover:after{opacity:.68}.subject-card:hover:before{opacity:1}.subject-card:hover{box-shadow:9px 9px 0 var(--ink);filter:saturate(1.14)}}.subject-card:active{box-shadow:none!important;transform:translate(6px,6px)!important}.subject-card-physics{min-height:195px;padding:26px}.subject-card-0{transform:translateY(30px)rotate(-1.5deg)}.subject-card-0.card-visible{transform:rotate(-1.5deg)translateY(-4px)}.subject-card-1{transform:translateY(30px)rotate(.8deg)translate(8px)}.subject-card-1.card-visible{transform:rotate(.8deg)translate(8px)translateY(-4px)}.subject-card-2{transform:translateY(30px)rotate(-.5deg)translateY(-6px)}.subject-card-2.card-visible{transform:rotate(-.5deg)translateY(-6px)}.subject-card-3{transform:translateY(30px)rotate(1.2deg)}.subject-card-3.card-visible{transform:rotate(1.2deg)translateY(-4px)}.subject-card-4{transform:translateY(30px)rotate(-.8deg)translate(-6px)}.subject-card-4.card-visible{transform:rotate(-.8deg)translate(-6px)translateY(-4px)}.subject-card-5{transform:translateY(30px)rotate(.5deg)translateY(4px)}.subject-card-5.card-visible{transform:rotate(.5deg)translateY(4px)}.subject-card span,.subject-card small{z-index:1;display:block;position:relative}.card-color-name{border:3px solid var(--ink);color:#fff;background:var(--accent);letter-spacing:.04em;z-index:2;border-radius:12px 2px;padding:4px 10px;font-size:11px;font-weight:800;display:inline-block}.card-realname{color:var(--ink);text-shadow:2px 2px 0 var(--accent);margin-top:12px;font-size:clamp(26px,3.5vw,40px);font-weight:900}@supports (color:color-mix(in lab, red, red)){.card-realname{text-shadow:2px 2px 0 color-mix(in srgb, var(--accent), #fff 24%)}}.card-realname{letter-spacing:.02em}.card-subject-name{color:var(--accent);margin-top:6px;font-size:clamp(14px,1.6vw,18px);font-weight:700}.subject-card small{color:#454145;margin-top:4px;font-size:clamp(12px,1vw,14px);font-weight:600;line-height:1.5}.homeroom-badge{color:var(--accent);background:var(--accent);border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;position:absolute;top:14px;right:14px}@supports (color:color-mix(in lab, red, red)){.homeroom-badge{background:color-mix(in srgb, var(--accent), transparent 82%)}}.homeroom-badge{letter-spacing:.04em;z-index:2}.selector-closing{text-align:center;color:#0000;opacity:0;cursor:pointer;background:linear-gradient(90deg,#ff6b6b,#ff90e8 16%,#ffd000 33%,#23f0c7 50%,#3b82f6 66%,#b088f9 83%,#ff6b6b) 0 0/200% 100%;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.2rem,1.6vw,1.5rem);font-weight:900;text-decoration:none;transition:opacity 1.2s;animation:16s linear infinite gradientShift;display:block}.selector-closing.closing-visible{opacity:.85}@keyframes gradientShift{0%{background-position:0%}to{background-position:-200%}}.footer-date{color:var(--ink);opacity:0;z-index:10;font-size:.7rem;transition:opacity 1s;position:fixed;bottom:clamp(14px,2vw,24px);right:clamp(14px,3vw,32px)}.footer-date.footer-visible{opacity:.15}.light-dots{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.light-dot{animation:dotFloat var(--duration,20s) ease-in-out infinite alternate;animation-delay:var(--delay,0s);filter:saturate(1.35);border-radius:50%;position:absolute}.light-dot-tri{border-style:solid;border-width:0 0 3px 3px;border-bottom-color:currentColor;border-left-color:currentColor;border-radius:0;transform:rotate(-45deg);background:0 0!important}.twinkle-layer,.shooting-layer,.bubble-layer,.watermark-text-layer,.journey-line-layer,.balloon-layer,.corner-doodle-layer{z-index:-1;pointer-events:none;position:fixed;inset:0;overflow:hidden}.twinkle-star{animation:twinkleDrift var(--twinkle-duration,25s) ease-in-out infinite;animation-delay:var(--twinkle-delay,0s);border-radius:50%;position:absolute}.shooting-star{width:var(--shoot-length,120px);background:linear-gradient(90deg, var(--shoot-color,#ff6b6b), transparent);opacity:0;transform-origin:0;height:2px;transform:rotate(var(--shoot-angle,25deg)) translateX(-100%);animation:shootFly var(--shoot-duration,1.5s) linear infinite;animation-delay:var(--shoot-delay,0s);border-radius:999px;position:absolute}.bubble{animation:bubbleFloat var(--bubble-duration,16s) ease-in-out infinite, bubbleBreathe 6s ease-in-out infinite;animation-delay:var(--bubble-delay,0s);background:0 0;border:1px solid;border-radius:50%;position:absolute}.watermark-text-layer{pointer-events:none;z-index:-1;flex-direction:column;align-items:flex-end;display:flex;position:fixed;top:clamp(60px,8vw,110px);right:clamp(20px,4vw,60px)}.wm-char{color:var(--pop-red);opacity:.5;letter-spacing:.08em;-webkit-user-select:none;user-select:none;font-family:Ma Shan Zheng,STXingkai,FZShuTi,cursive,serif;font-size:clamp(80px,14vw,200px);font-weight:900;line-height:1.1}.wm-char-1{color:#ff90e8;font-size:clamp(100px,16vw,240px)}.wm-char-2{color:#ffe66d;font-size:clamp(80px,13vw,200px)}.wm-char-3{color:#b088f9;font-size:clamp(65px,10vw,170px)}.journey-line-layer{width:12px;padding-left:4px;position:fixed;top:15%;bottom:15%;left:clamp(28px,4vw,60px)}.journey-line{border-left:3px dashed #15151529;width:1px;height:100%;position:relative}.journey-line:before,.journey-line:after{content:"";background:var(--pop-pink);border:2px solid var(--ink);border-radius:50%;width:7px;height:7px;position:absolute;left:-3px}.journey-line:before{top:0}.journey-line:after{bottom:0}.corner-doodle-layer{position:fixed;inset:0}.corner-doodle{stroke:#1515152e;fill:none;width:50px;height:50px;position:absolute}.corner-doodle-tl{top:clamp(20px,3vw,40px);left:clamp(20px,3vw,40px)}.corner-doodle-br{bottom:clamp(20px,3vw,40px);right:clamp(20px,3vw,40px)}.balloon{pointer-events:none;object-fit:contain;opacity:.56;filter:saturate(1.35)brightness(1.06)drop-shadow(3px 3px #15151538);animation:balloonFloat var(--balloon-dur,5s) ease-in-out infinite;animation-delay:var(--balloon-delay,0s);position:absolute}@keyframes balloonFloat{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-12px)rotate(2deg)}}@keyframes twinkleDrift{0%{transform:translate(0)}25%{transform:translate(var(--twinkle-dx,10px), var(--twinkle-dy,-10px))}50%{transform:translate(calc(var(--twinkle-dx,10px) * -.5), calc(var(--twinkle-dy,-10px) * -.5))}75%{transform:translate(calc(var(--twinkle-dx,10px) * .3), calc(var(--twinkle-dy,-10px) * .3))}to{transform:translate(0)}}@keyframes shootFly{0%{opacity:0;transform:rotate(var(--shoot-angle,25deg)) translateX(-100%)}4%{opacity:.9}50%{opacity:.7}70%{opacity:0;transform:rotate(var(--shoot-angle,25deg)) translateX(calc(100vw + 100%))}to{opacity:0}}@keyframes bubbleFloat{0%,to{translate:0}50%{translate:var(--bubble-dx,8px) var(--bubble-dy,-20px)}}@keyframes bubbleBreathe{0%,to{scale:var(--bubble-scale-from,.9)}50%{scale:var(--bubble-scale-to,1.1)}}@keyframes fadeInSimple{0%{opacity:0}to{opacity:1}}@keyframes titleSlideUp{0%{opacity:0;filter:blur(6px);transform:translateY(16px)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes dotFloat{0%{transform:translate(0)}to{transform:translate(var(--dx,10px), var(--dy,-10px))}}.teacher-page{z-index:1;padding:clamp(20px,4vw,56px);position:relative;overflow:hidden}.teacher-page:before{content:"";z-index:0;background:radial-gradient(circle at 12% 14%, var(--accent) 0 44px, transparent 46px), radial-gradient(circle at 86% 22%, var(--secondary) 0 58px, transparent 60px), radial-gradient(circle at 68% 86%, #ffe74c6b 0 52px, transparent 54px), repeating-linear-gradient(118deg, transparent 0 30px, #1515150b 31px 33px);position:absolute;inset:0}@supports (color:color-mix(in lab, red, red)){.teacher-page:before{background:radial-gradient(circle at 12% 14%, color-mix(in srgb, var(--accent), transparent 54%) 0 44px, transparent 46px), radial-gradient(circle at 86% 22%, color-mix(in srgb, var(--secondary), transparent 46%) 0 58px, transparent 60px), radial-gradient(circle at 68% 86%, #ffe74c6b 0 52px, transparent 54px), repeating-linear-gradient(118deg, transparent 0 30px, #1515150b 31px 33px)}}.teacher-page:before{pointer-events:none;mix-blend-mode:multiply}.flashlight-beam{z-index:0;pointer-events:none;background:conic-gradient(from 210deg at 5% 5%, transparent 0deg, var(--accent) 15deg, var(--accent) 25deg, var(--accent) 35deg, transparent 50deg, transparent 360deg);width:120%;height:120%;position:absolute;top:-10%;left:-10%}@supports (color:color-mix(in lab, red, red)){.flashlight-beam{background:conic-gradient(from 210deg at 5% 5%, transparent 0deg, color-mix(in srgb, var(--accent), transparent 75%) 15deg, color-mix(in srgb, var(--accent), transparent 60%) 25deg, color-mix(in srgb, var(--accent), transparent 75%) 35deg, transparent 50deg, transparent 360deg)}}.flashlight-beam{-webkit-mask-image:radial-gradient(60% 50% at 5% 5%,#000 10%,#0000 60%);mask-image:radial-gradient(60% 50% at 5% 5%,#000 10%,#0000 60%)}.ambient{pointer-events:none;filter:blur(1px)saturate(1.25);opacity:.48;position:absolute}.ambient-one{background:var(--secondary);border-radius:42% 58% 47% 53%;width:280px;height:280px;animation:10s ease-in-out infinite alternate drift;inset:90px auto auto -120px}.ambient-two{background:var(--accent);border-radius:54% 46% 60% 40%;width:230px;height:230px;bottom:140px;right:-110px}@supports (color:color-mix(in lab, red, red)){.ambient-two{background:color-mix(in srgb, var(--accent), #fff 42%)}}.ambient-two{animation:12s ease-in-out infinite alternate-reverse drift}.subject-decor{z-index:0;pointer-events:none;position:absolute;inset:0;overflow:hidden}.star-field,.meteor-field,.paper-plane-field,.sakura-field,.motif-cloud,.floating-assets{position:absolute;inset:0}.star-field span{width:4px;height:4px;box-shadow:0 0 12px #fff, 0 0 22px var(--accent);background:#fff;border-radius:50%;position:absolute}@supports (color:color-mix(in lab, red, red)){.star-field span{box-shadow:0 0 12px #fff, 0 0 22px color-mix(in srgb, var(--accent), #fff 28%)}}.star-field span{opacity:.62;animation:2.8s ease-in-out infinite twinkle;animation-delay:calc(var(--i) * -.18s)}.star-field span:nth-child(3n){width:6px;height:6px}.star-field span:nth-child(4n){width:3px;height:3px}.meteor-field{opacity:.72}.meteor-field span{background:linear-gradient(90deg, transparent, #ffffffeb, var(--accent));width:clamp(80px,12vw,150px);height:2px;box-shadow:0 0 18px var(--accent);border-radius:999px;position:absolute}@supports (color:color-mix(in lab, red, red)){.meteor-field span{box-shadow:0 0 18px color-mix(in srgb, var(--accent), #fff 22%)}}.meteor-field span{opacity:0;animation:6.8s ease-in-out infinite meteorFly;animation-delay:calc(var(--i) * 1.05s);transform:rotate(28deg)translate(-160px)}.meteor-field span:first-child{top:16%;left:12%}.meteor-field span:nth-child(2){top:13%;left:44%}.meteor-field span:nth-child(3){top:38%;left:24%}.meteor-field span:nth-child(4){top:48%;left:63%}.meteor-field span:nth-child(5){top:68%;left:8%}.meteor-field span:nth-child(6){top:72%;left:48%}.paper-plane-field{opacity:.72}.paper-plane-field span{width:clamp(34px,4.6vw,66px);color:var(--accent);display:block;position:absolute}@supports (color:color-mix(in lab, red, red)){.paper-plane-field span{color:color-mix(in srgb, var(--accent), #fff 22%)}}.paper-plane-field span{filter:drop-shadow(0 14px 24px var(--accent))}@supports (color:color-mix(in lab, red, red)){.paper-plane-field span{filter:drop-shadow(0 14px 24px color-mix(in srgb, var(--accent), transparent 70%))}}.paper-plane-field span{opacity:0;offset-path:path("M -80 70 C 180 -30, 350 170, 560 70 S 910 20, 1240 150");offset-rotate:auto;animation:12s cubic-bezier(.42,0,.22,1) infinite planeGlide;animation-delay:calc(var(--i) * 3.1s)}.paper-plane-field span:first-child{top:26%;left:-8%}.paper-plane-field span:nth-child(2){offset-path:path("M -90 120 C 170 250, 370 -10, 610 120 S 970 250, 1280 60");top:53%;left:-10%}.paper-plane-field span:nth-child(3){offset-path:path("M -140 80 C 140 -20, 290 180, 520 90 S 870 -20, 1220 130");top:76%;left:18%}.paper-plane-field svg{width:100%;height:auto;display:block;transform:rotate(18deg)}.paper-plane-field path{fill:#ffffff57;stroke:currentColor;stroke-width:3.2px;stroke-linejoin:round;stroke-linecap:round}.sakura-petal{opacity:.65;width:clamp(18px,2.5vw,32px);height:clamp(18px,2.5vw,32px);animation:15s linear infinite sakuraPetalFall;animation-delay:calc(var(--i) * -.85s);position:absolute}.sakura-petal img{object-fit:contain;filter:drop-shadow(0 2px 4px #d86f934d)brightness(.95)contrast(1.1);width:100%;height:100%}.sakura-petal:first-child{top:18%;left:8%}.sakura-petal:nth-child(2){top:42%;left:19%}.sakura-petal:nth-child(3){top:15%;left:31%}.sakura-petal:nth-child(4){top:56%;left:41%}.sakura-petal:nth-child(5){top:24%;left:52%}.sakura-petal:nth-child(6){top:48%;left:63%}.sakura-petal:nth-child(7){top:14%;left:74%}.sakura-petal:nth-child(8){top:38%;left:86%}.sakura-petal:nth-child(9){top:68%;left:13%}.sakura-petal:nth-child(10){top:76%;left:27%}.sakura-petal:nth-child(11){top:74%;left:47%}.sakura-petal:nth-child(12){top:70%;left:68%}.sakura-petal:nth-child(13){top:66%;left:91%}.sakura-petal:nth-child(14){top:34%;left:36%}.sakura-petal:nth-child(15){top:10%;left:58%}.sakura-petal:nth-child(16){top:82%;left:80%}.sakura-petal:nth-child(17){top:52%;left:5%}.sakura-petal:nth-child(18){top:31%;left:72%}.sakura-blossom{opacity:.55;width:clamp(50px,6.5vw,90px);height:clamp(50px,6.5vw,90px);animation:14s ease-in-out infinite alternate sakuraBlossomDrift;animation-delay:calc(var(--i) * -1.8s);position:absolute}.sakura-blossom img{object-fit:contain;filter:drop-shadow(0 3px 6px #d86f9359)brightness(.95)contrast(1.1);width:100%;height:100%}.sakura-blossom:nth-child(19){top:22%;left:22%}.sakura-blossom:nth-child(20){top:38%;left:57%;scale:.82}.sakura-blossom:nth-child(21){top:58%;left:78%;scale:.72}.sakura-blossom:nth-child(22){top:70%;left:38%;scale:.9}.sakura-blossom:nth-child(23){top:80%;left:12%;scale:.68}.star-field span:first-child{top:18%;left:9%}.star-field span:nth-child(2){top:74%;left:22%}.star-field span:nth-child(3){top:12%;left:31%}.star-field span:nth-child(4){top:62%;left:46%}.star-field span:nth-child(5){top:20%;left:58%}.star-field span:nth-child(6){top:72%;left:72%}.star-field span:nth-child(7){top:16%;left:84%}.star-field span:nth-child(8){top:48%;left:93%}.star-field span:nth-child(9){top:46%;left:14%}.star-field span:nth-child(10){top:86%;left:38%}.star-field span:nth-child(11){top:42%;left:64%}.star-field span:nth-child(12){top:88%;left:80%}.star-field span:nth-child(13){top:88%;left:5%}.star-field span:nth-child(14){top:36%;left:27%}.star-field span:nth-child(15){top:8%;left:51%}.star-field span:nth-child(16){top:10%;left:69%}.star-field span:nth-child(17){top:66%;left:88%}.star-field span:nth-child(18){top:28%;left:42%}.motif-cloud b{color:var(--accent);display:block;position:absolute}@supports (color:color-mix(in lab, red, red)){.motif-cloud b{color:color-mix(in srgb, var(--accent), transparent 45%)}}.motif-cloud b{opacity:.2;white-space:nowrap;text-shadow:0 12px 34px var(--accent);font-family:Noto Serif SC,Georgia,Times New Roman,serif;font-size:clamp(20px,2.5vw,38px);font-weight:700}@supports (color:color-mix(in lab, red, red)){.motif-cloud b{text-shadow:0 12px 34px color-mix(in srgb, var(--accent), transparent 78%)}}.motif-cloud b{animation:8s ease-in-out infinite alternate floatText;animation-delay:calc(var(--i) * -.8s)}.motif-cloud b:first-child{top:18%;left:30%;transform:rotate(-8deg)}.motif-cloud b:nth-child(2){top:28%;left:43%;transform:rotate(7deg)}.motif-cloud b:nth-child(3){top:42%;left:32%;transform:rotate(5deg)}.motif-cloud b:nth-child(4){top:51%;left:50%;transform:rotate(-6deg)}.motif-cloud b:nth-child(5){top:60%;left:38%;transform:rotate(3deg)}.motif-cloud b:nth-child(6){top:36%;left:56%;transform:rotate(-4deg)}.dna-strand,.chem-structure{opacity:.24;width:min(32vw,310px);max-height:58vh;color:var(--accent);filter:drop-shadow(0 22px 40px var(--accent));position:absolute;top:120px;right:clamp(18px,6vw,90px)}@supports (color:color-mix(in lab, red, red)){.dna-strand,.chem-structure{filter:drop-shadow(0 22px 40px color-mix(in srgb, var(--accent), transparent 72%))}}.dna-strand{animation:8s ease-in-out infinite alternate slowRise}.dna-strand path,.dna-strand line{fill:none;stroke:currentColor;stroke-width:4px;stroke-linecap:round}.dna-strand circle{fill:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.dna-strand circle{fill:color-mix(in srgb, var(--secondary), #fff 18%)}}.dna-strand circle{stroke:currentColor;stroke-width:2px}.chem-structure{animation:10s ease-in-out infinite alternate moleculeFloat;top:155px}.chem-structure polygon,.chem-structure line{fill:none;stroke:currentColor;stroke-width:5px;stroke-linecap:round;stroke-linejoin:round}.chem-structure circle{fill:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.chem-structure circle{fill:color-mix(in srgb, var(--secondary), #fff 22%)}}.chem-structure circle{stroke:currentColor;stroke-width:4px}.chem-structure text{fill:currentColor;font-size:28px;font-weight:800}.subject-decor-physics .motif-cloud b,.subject-decor-math .motif-cloud b{opacity:.27;font-family:Cambria Math,Georgia,Times New Roman,serif}.subject-decor-chinese .motif-cloud b{writing-mode:vertical-rl;letter-spacing:.08em;white-space:normal;opacity:.34;max-height:360px;font-family:STXingkai,FZShuTi,LiSu,KaiTi,Microsoft YaHei,serif;line-height:1.7}.subject-decor-chinese .motif-cloud b span{white-space:nowrap;margin-left:16px;display:block}.subject-decor-chinese .motif-cloud b:first-child{top:16%;left:33%}.subject-decor-chinese .motif-cloud b:nth-child(2){max-height:none;top:18%;left:49%}.subject-decor-chinese .motif-cloud b:nth-child(3){top:14%;left:62%}.chinese-extra-quote{z-index:0;width:auto;color:var(--accent);position:absolute;top:clamp(560px,70vh,740px);left:clamp(32px,7vw,112px)}@supports (color:color-mix(in lab, red, red)){.chinese-extra-quote{color:color-mix(in srgb, var(--accent), transparent 30%)}}.chinese-extra-quote{opacity:.32;text-shadow:0 16px 36px var(--accent);font-family:STXingkai,FZShuTi,LiSu,KaiTi,Microsoft YaHei,serif;font-size:clamp(22px,2.8vw,42px);font-weight:700;line-height:1.3}@supports (color:color-mix(in lab, red, red)){.chinese-extra-quote{text-shadow:0 16px 36px color-mix(in srgb, var(--accent), transparent 74%)}}.chinese-extra-quote{animation:6.5s ease-in-out infinite alternate quoteFloat}.subject-decor-english .motif-cloud b{white-space:normal;letter-spacing:0;opacity:.3;max-width:min(42vw,520px);font-family:Georgia,Times New Roman,Segoe Script,cursive,serif;font-style:italic;font-weight:700;line-height:1.3}.subject-decor-english .motif-cloud b:first-child{top:18%;left:30%}.subject-decor-english .motif-cloud b:nth-child(2){top:33%;left:39%}.subject-decor-english .motif-cloud b:nth-child(3){max-width:min(50vw,620px);top:48%;left:28%}.subject-decor-english .floating-assets img:first-child{top:30%;left:9%}.subject-decor-english .floating-assets img:nth-child(2){top:22%;left:73%}.subject-decor-english .floating-assets img:nth-child(3){top:60%;left:65%}.subject-decor-math .motif-cloud b:first-child{top:16%;left:30%}.subject-decor-math .motif-cloud b:nth-child(2){white-space:normal;max-width:min(46vw,620px);top:31%;left:29%}.subject-decor-math .motif-cloud b:nth-child(3){top:43%;left:50%}.subject-decor-math .motif-cloud b:nth-child(4){top:54%;left:34%}.subject-decor-math .motif-cloud b:nth-child(5){top:25%;left:56%}.subject-decor-math .floating-assets img:nth-child(2),.subject-decor-math .floating-assets img:nth-child(7),.subject-decor-math .floating-assets img:nth-child(9){opacity:.1}.floating-assets img{object-fit:contain;opacity:.15;width:clamp(58px,8vw,118px);height:auto;filter:drop-shadow(0 18px 30px var(--accent)) saturate(.92);position:absolute}@supports (color:color-mix(in lab, red, red)){.floating-assets img{filter:drop-shadow(0 18px 30px color-mix(in srgb, var(--accent), transparent 76%)) saturate(.92)}}.floating-assets img{animation:5.6s ease-in-out infinite alternate assetFloat,7.5s ease-in-out infinite alternate softSpin;animation-delay:calc(var(--i) * -.82s), calc(var(--i) * -1.35s)}.floating-assets img:first-child{top:19%;left:8%;transform:rotate(-8deg)}.floating-assets img:nth-child(2){width:clamp(68px,9vw,136px);top:17%;left:67%;transform:rotate(10deg)}.floating-assets img:nth-child(3){width:clamp(58px,8vw,118px);top:30%;left:23%;transform:rotate(6deg)}.floating-assets img:nth-child(4){width:clamp(56px,7vw,112px);top:38%;left:79%;transform:rotate(-12deg)}.floating-assets img:nth-child(5){width:clamp(58px,7vw,108px);top:55%;left:14%;transform:rotate(14deg)}.floating-assets img:nth-child(6){width:clamp(64px,8vw,124px);top:59%;left:58%;transform:rotate(-10deg)}.floating-assets img:nth-child(7){opacity:.13;width:clamp(48px,6vw,90px);top:13%;left:39%;transform:rotate(18deg)}.floating-assets img:nth-child(8){opacity:.13;width:clamp(52px,7vw,104px);top:68%;left:34%;transform:rotate(-16deg)}.floating-assets img:nth-child(9){opacity:.12;width:clamp(48px,6vw,92px);top:21%;left:49%;transform:rotate(7deg)}.floating-assets img:nth-child(10){opacity:.13;width:clamp(52px,7vw,104px);top:66%;left:72%;transform:rotate(12deg)}.floating-assets img:nth-child(11){opacity:.12;width:clamp(48px,6vw,96px);top:72%;left:4%;transform:rotate(-7deg)}.subject-decor-math .floating-assets img,.subject-decor-physics .floating-assets img{opacity:.14}.subject-decor-chemistry .floating-assets img,.subject-decor-biology .floating-assets img{opacity:.17}@keyframes effect{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes drift{0%{transform:translate(0)rotate(0)}to{transform:translate(18px,-22px)rotate(12deg)}}@keyframes assetFloat{0%{translate:-8px 10px}to{translate:26px -34px}}@keyframes softSpin{0%{rotate:-7deg}to{rotate:8deg}}@keyframes twinkle{0%,to{opacity:.28;transform:scale(.7)}45%{opacity:.88;transform:scale(1.45)}}@keyframes floatText{0%{translate:-6px 8px}to{translate:24px -26px}}@keyframes meteorFly{0%,18%{opacity:0;transform:rotate(28deg)translate(-170px)}28%{opacity:.86}48%{opacity:0;transform:rotate(28deg)translate(190px)}to{opacity:0;transform:rotate(28deg)translate(190px)}}@keyframes planeGlide{0%{opacity:0;offset-distance:0%;transform:scale(.78)}12%{opacity:.72}45%{transform:scale(1)}72%{opacity:.66;transform:scale(.92)}to{opacity:0;offset-distance:100%;transform:scale(.86)}}@keyframes sakuraPetalFall{0%{opacity:0;transform:translateY(-40px)translate(0)rotate(0)}5%{opacity:.7}25%{transform:translateY(60px)translate(20px)rotate(90deg)}50%{transform:translateY(160px)translate(-15px)rotate(180deg)}75%{opacity:.6;transform:translateY(260px)translate(25px)rotate(270deg)}to{opacity:0;transform:translateY(380px)translate(-10px)rotate(360deg)}}@keyframes sakuraBlossomDrift{0%{translate:0;rotate:0deg}20%{translate:8px -6px;rotate:5deg}40%{translate:-4px 10px;rotate:-8deg}60%{translate:12px 4px;rotate:10deg}80%{translate:-6px -8px;rotate:-5deg}to{translate:5px 6px;rotate:3deg}}@keyframes quoteFloat{0%{translate:-6px 6px}to{translate:16px -14px}}@keyframes slowRise{0%{transform:translateY(18px)rotate(-5deg)}to{transform:translateY(-12px)rotate(5deg)}}@keyframes moleculeFloat{0%{transform:translateY(14px)rotate(-4deg)}to{transform:translate(-18px,-12px)rotate(5deg)}}.hero-grid{z-index:1;grid-template-columns:minmax(0,.92fr) minmax(420px,1.08fr);align-items:center;gap:clamp(28px,5vw,70px);min-height:65vh;display:grid;position:relative}.hero-copy{max-width:650px}.eyebrow{border:3px solid var(--ink);color:var(--accent);letter-spacing:.08em;background:linear-gradient(90deg, #fff 0 62%, var(--secondary) 62%), #fff;border-radius:18px 5px 16px 6px;align-items:center;gap:8px;margin-top:24px;padding:8px 16px;font-size:14px;font-weight:800;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.eyebrow{background:linear-gradient(90deg, #fff 0 62%, color-mix(in srgb, var(--secondary), #fff 18%) 62%), #fff}}.eyebrow{box-shadow:var(--doodle-shadow-small);transform:rotate(-1deg)}h1,h2,p{margin:0}h1{letter-spacing:0;color:var(--ink);text-shadow:4px 4px 0 var(--accent), 8px 8px 0 var(--pop-yellow);margin-top:22px;font-size:clamp(64px,10vw,140px);font-weight:900;line-height:.88}.subject{color:var(--accent);text-shadow:2px 2px #fff;margin-top:18px;font-size:clamp(24px,3.5vw,42px);font-style:italic;font-weight:800}.teacher-realname{color:var(--accent);letter-spacing:.04em;clip-path:inset(0 100% 0 0);transform-origin:0 100%;text-shadow:2px 2px 0 #fff, 4px 4px 0 var(--accent);margin-top:18px;font-family:HYShangWeiShouShu,Ma Shan Zheng,STXingkai,FZShuTi,cursive,serif;font-size:clamp(36px,5.5vw,64px);font-weight:400;line-height:1.1;animation:.8s cubic-bezier(.25,.46,.45,.94) forwards handwrite,2s ease-in-out .8s infinite alternate handwrite-wobble;position:relative}@supports (color:color-mix(in lab, red, red)){.teacher-realname{text-shadow:2px 2px 0 #fff, 4px 4px 0 color-mix(in srgb, var(--accent), transparent 34%)}}.teacher-realname:after{content:"";background:repeating-linear-gradient(90deg, var(--accent) 0 12px, transparent 12px 18px);opacity:.78;clip-path:inset(0 100% 0 0);width:100%;height:7px;animation:.6s cubic-bezier(.25,.46,.45,.94) .5s forwards handwrite-underline;position:absolute;bottom:2px;left:0}@keyframes handwrite{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0% 0 0)}}@keyframes handwrite-underline{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0% 0 0)}}@keyframes handwrite-wobble{0%{transform:rotate(-.5deg)translateY(0)}to{transform:rotate(.5deg)translateY(-1px)}}.message{max-width:560px;color:var(--ink);border:4px solid var(--ink);background:radial-gradient(circle at 96% 12%, var(--secondary) 0 28px, transparent 29px), linear-gradient(135deg, #fff 0 64%, var(--accent) 64%), #fff;border-radius:24px 6px 22px 8px;margin-top:26px;padding:20px;font-size:clamp(15px,1.4vw,18px);font-weight:600;line-height:1.8}@supports (color:color-mix(in lab, red, red)){.message{background:radial-gradient(circle at 96% 12%, color-mix(in srgb, var(--secondary), #fff 12%) 0 28px, transparent 29px), linear-gradient(135deg, #fff 0 64%, color-mix(in srgb, var(--accent), #fff 70%) 64%), #fff}}.message{box-shadow:7px 7px 0 var(--accent)}@supports (color:color-mix(in lab, red, red)){.message{box-shadow:7px 7px 0 color-mix(in srgb, var(--accent), var(--ink) 15%)}}.message{transform:rotate(-.35deg)}.song-bar{border:4px solid var(--ink);max-width:420px;box-shadow:var(--doodle-shadow);background:repeating-linear-gradient(-45deg,#ffe74c3d 0 10px,#0000 10px 20px),#fff;border-radius:22px 6px 20px 7px;grid-template-columns:46px minmax(0,1fr) 46px;align-items:center;gap:12px;margin-top:34px;padding:12px;display:grid}.song-mark{border:3px solid var(--ink);width:46px;height:46px;color:var(--ink);background:var(--pop-yellow);box-shadow:var(--doodle-shadow-small);border-radius:50%;place-items:center;display:grid}.song-bar span,.song-bar small{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.song-bar span{color:#1a1a1a;font-weight:800}.song-bar small{color:#666;margin-top:3px;font-weight:600}.teacher-quote{max-width:520px;color:var(--accent);margin-top:28px}@supports (color:color-mix(in lab, red, red)){.teacher-quote{color:color-mix(in srgb, var(--accent), #48504c 50%)}}.teacher-quote{border-left:3px solid var(--accent);padding-left:20px;font-family:Noto Serif SC,Source Han Serif SC,Georgia,serif;font-size:clamp(15px,1.4vw,19px);font-style:italic;line-height:1.9;position:relative}@supports (color:color-mix(in lab, red, red)){.teacher-quote{border-left:3px solid color-mix(in srgb, var(--accent), transparent 60%)}}.teacher-quote{opacity:0;animation:.6s .4s forwards quoteReveal}@keyframes quoteReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.photo-collage{min-height:650px;position:relative}.photo-card{border:5px solid var(--ink);background:linear-gradient(135deg, var(--pop-yellow) 0 16px, #fff 16px), #fff;box-shadow:9px 9px 0 var(--ink), 14px 14px 0 var(--accent);border-radius:20px 5px 18px 7px;margin:0;position:absolute;overflow:hidden}@supports (color:color-mix(in lab, red, red)){.photo-card{box-shadow:9px 9px 0 var(--ink), 14px 14px 0 color-mix(in srgb, var(--accent), transparent 32%)}}.photo-card{transition:transform .4s cubic-bezier(.23,1,.32,1)}.photo-card:hover{box-shadow:7px 7px 0 var(--ink), 13px 13px 0 var(--accent);transform:scale(1.03)rotate(0)!important}.photo-card img{object-fit:cover;width:100%;height:100%;display:block}.photo-card img.missing{display:none}.photo-placeholder{text-align:center;width:100%;height:100%;color:var(--accent);place-items:center;padding:24px;display:none}@supports (color:color-mix(in lab, red, red)){.photo-placeholder{color:color-mix(in srgb, var(--accent), #1f2523 24%)}}.photo-placeholder{background:linear-gradient(135deg, #ffffffc2, #ffffff4d), repeating-linear-gradient(-45deg, var(--secondary) 0 12px, #ffffffa6 12px 24px)}@supports (color:color-mix(in lab, red, red)){.photo-placeholder{background:linear-gradient(135deg, #ffffffc2, #ffffff4d), repeating-linear-gradient(-45deg, color-mix(in srgb, var(--secondary), #fff 30%) 0 12px, #ffffffa6 12px 24px)}}.photo-card img.missing+.photo-placeholder{display:grid}.photo-placeholder span{max-width:260px;font-weight:700;line-height:1.55}.photo-card figcaption{border:3px solid var(--ink);border-left:6px solid var(--accent);color:var(--ink);box-shadow:var(--doodle-shadow-small);background:linear-gradient(90deg,#ffe74c8c,#fffffff5 38%),#fffffff5;border-radius:12px 4px;padding:12px 14px;font-size:14px;font-weight:700;line-height:1.45;position:absolute;bottom:14px;left:14px;right:14px}.photo-card-0{aspect-ratio:16/10;width:min(78%,540px);top:10px;right:58px;transform:rotate(-2deg)}.photo-card-1{aspect-ratio:4/3;width:min(54%,390px);top:310px;left:0;transform:rotate(1.5deg)}.photo-card-2{aspect-ratio:3/4;width:min(42%,300px);bottom:10px;right:0;transform:rotate(-1deg)}.lower-grid{z-index:1;grid-template-columns:minmax(0,.95fr) minmax(320px,.7fr);gap:18px;margin-top:24px;display:grid;position:relative}.memory-panel{border:4px solid var(--ink);box-shadow:8px 8px 0 var(--pop-red);background:radial-gradient(circle at 96% 8%,#ff4fd852 0 24px,#0000 25px),repeating-linear-gradient(0deg,#0000 0 31px,#1515150b 32px 34px),#fff;border-radius:24px 6px 20px 7px;padding:clamp(20px,3vw,32px);position:relative}.memory-panel:before{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#ffffff26,#0000 50%);position:absolute;inset:0}.lyrics-panel{border:4px solid var(--ink);box-shadow:8px 8px 0 var(--pop-purple);background:radial-gradient(circle at 96% 8%,#2df7b557 0 24px,#0000 25px),repeating-linear-gradient(90deg,#0000 0 30px,#9b5cff0f 31px 34px),#fff;border-radius:24px 6px 20px 7px;padding:clamp(20px,3vw,32px);position:relative}.lyrics-panel:before{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#ffffff26,#0000 50%);position:absolute;inset:0}.memory-panel h2,.lyrics-panel h2{color:var(--ink);font-size:22px}.memory-window{height:220px;margin-top:14px;overflow:hidden;-webkit-mask-image:linear-gradient(#0000,#000 15% 85%,#0000);mask-image:linear-gradient(#0000,#000 15% 85%,#0000)}.memory-list{flex-direction:column;gap:16px;display:flex}.memory-item{color:#3d3941;opacity:0;align-items:flex-start;gap:12px;padding:12px 0;font-size:clamp(15px,1.4vw,19px);line-height:1.7;animation:1.5s ease-out forwards memoryFadeIn;display:flex;margin-top:0!important}.memory-bullet{background-color:var(--accent);opacity:1;border:2px solid var(--ink);width:10px;min-width:10px;height:10px;box-shadow:2px 2px 0 var(--pop-yellow);border-radius:50%;margin-top:10px;display:inline-block}.memory-item:first-child{animation-delay:2.2s}.memory-item:nth-child(2){animation-delay:2.8s}.memory-item:nth-child(3){animation-delay:3.4s}.memory-item:nth-child(4){animation-delay:4s}@keyframes memoryFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}code{color:var(--accent);background:var(--secondary);border-radius:6px;padding:2px 6px}@supports (color:color-mix(in lab, red, red)){code{background:color-mix(in srgb, var(--secondary), #fff 55%)}}code{font-family:DM Mono,monospace}.panel-title{color:var(--accent);align-items:center;gap:8px;font-weight:700;display:flex}.lyrics-window{contain:layout paint;height:220px;margin-top:14px;position:relative;overflow:hidden;transform:translateZ(0)}.lyrics-window:before,.lyrics-window:after{content:"";z-index:2;pointer-events:none;height:34px;position:absolute;left:0;right:0}.lyrics-window:before{background:linear-gradient(#fff,#fff0);top:0}.lyrics-window:after{background:linear-gradient(#fff0,#fff);bottom:0}.lyrics-content{will-change:transform;transition:transform .2s cubic-bezier(.22,1,.36,1);transform:translateZ(0)}.lyrics-window p{color:#746978;opacity:.45;will-change:opacity, transform;padding:12px 0;font-size:20px;line-height:1.6;transition:color .16s,opacity .16s,transform .18s cubic-bezier(.22,1,.36,1),background-color .16s,box-shadow .16s;transform:scale(.97)}.lyrics-window p.active{color:var(--ink);background:linear-gradient(90deg, var(--accent), var(--secondary))}@supports (color:color-mix(in lab, red, red)){.lyrics-window p.active{background:linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--secondary), #fff 12%))}}.lyrics-window p.active{opacity:1;transform-origin:0;border:3px solid var(--ink);box-shadow:var(--doodle-shadow-small);border-radius:15px 4px 14px 5px;padding:8px 16px;font-weight:800;transform:translate(8px)scale(1.03)}.page-controls{z-index:25;border:4px solid var(--ink);box-shadow:var(--doodle-shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(90deg,#ff4fd8f0,#25d9fff0,#ffe74cf0);border-radius:22px 6px 20px 7px;align-items:center;gap:12px;padding:10px;display:flex;position:fixed;bottom:18px;left:50%;transform:translate(-50%)}.page-controls span{text-align:center;min-width:54px;color:var(--ink);font-weight:800}.btn{border:3px solid var(--ink);cursor:pointer;min-width:42px;min-height:42px;box-shadow:var(--doodle-shadow-small);border-radius:14px 5px 13px;place-items:center;transition:all .15s;display:inline-grid}.btn:hover{transform:translate(2px,2px);box-shadow:1px 1px #000}.btn:active{box-shadow:none;transform:translate(3px,3px)}.btn-solid{color:var(--ink);background:var(--accent)}.btn-outline,.btn-ghost{color:var(--ink);background:#fff}.btn-outline{border:1px solid #1f25231f}.btn-ghost:hover,.btn-outline:hover{background:#fff;box-shadow:0 8px 24px #1f25231a}.unlock-layer{z-index:30;color:#fff;background:var(--accent);border:1px solid #fff9;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;display:inline-flex;position:fixed;top:78px;right:clamp(16px,4vw,52px)}@supports (color:color-mix(in lab, red, red)){.unlock-layer{background:color-mix(in srgb, var(--accent), #1f2523 8%)}}.unlock-layer{box-shadow:0 14px 32px var(--accent)}@supports (color:color-mix(in lab, red, red)){.unlock-layer{box-shadow:0 14px 32px color-mix(in srgb, var(--accent), transparent 64%)}}.unlock-layer{cursor:pointer}.prologue-overlay{z-index:100;background:radial-gradient(circle at 22% 18%,#ff4fd86b 0 12%,#0000 13%),radial-gradient(circle at 82% 24%,#25d9ff61 0 10%,#0000 11%),radial-gradient(circle at 72% 78%,#ffe74c8a 0 13%,#0000 14%),linear-gradient(135deg,#fff7df,#fff0fb 46%,#eafff8);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.prologue-particles{pointer-events:none;position:absolute;inset:0}.prologue-particle{background:var(--pop-pink);opacity:.72;border-radius:50%;position:absolute;box-shadow:0 0 6px #1f252326,0 0 16px #1f252314}.prologue-text-wrapper{text-align:center;z-index:1;position:relative}.prologue-text{color:#6b3764;letter-spacing:.15em;margin:0;font-size:clamp(18px,3vw,28px)}.prologue-number-row{justify-content:center;align-items:baseline;gap:12px;margin-top:16px;display:flex}.prologue-number{color:var(--ink);letter-spacing:0;text-shadow:5px 5px 0 var(--pop-yellow), 10px 10px 0 var(--pop-pink);font-size:clamp(72px,15vw,160px);font-weight:700;line-height:1}.prologue-unit{color:var(--ink);font-size:clamp(28px,5vw,48px);font-weight:400}.prologue-hint{color:#7a366d;letter-spacing:.3em;margin:0;font-size:clamp(13px,1.5vw,16px);position:absolute;bottom:clamp(60px,10vh,120px)}.prologue-timeline{flex-direction:column;gap:32px;display:flex;position:absolute;top:50%;right:clamp(40px,8vw,120px);transform:translateY(-50%)}.prologue-timeline-line{background:linear-gradient(to bottom, transparent, var(--pop-pink) 20%, var(--pop-cyan) 50%, var(--pop-yellow) 80%, transparent);transform-origin:top;width:1px;position:absolute;top:8px;bottom:8px;left:4px}.prologue-timeline-node{align-items:center;gap:14px;display:flex;position:relative}.prologue-timeline-dot{background:var(--pop-yellow);border:2px solid var(--ink);opacity:1;z-index:1;border-radius:50%;width:9px;min-width:9px;height:9px;position:relative}.prologue-timeline-text{flex-direction:column;gap:2px;display:flex}.prologue-timeline-year{color:var(--ink);letter-spacing:.05em;font-size:clamp(14px,1.5vw,18px)}.prologue-timeline-label{color:#6b5a64;font-size:clamp(11px,1vw,13px)}@keyframes float{0%{transform:translate(-20px,20px)}50%{transform:translateY(50px)}to{transform:translate(-20px,20px)}}
