@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-space-y-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight: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-outline-style:solid;--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-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:"IBM Plex Sans JP", "Noto Sans TC", "Microsoft JhengHei", "PingFang TC", "Arial", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Consolas", monospace;--color-red-500:#fb2c36;--color-amber-500:#f99c00;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-medium:500;--font-weight-semibold:600;--leading-tight:1.25;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--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);--color-primary:#0184ff;--color-primary-light:#33a1ff;--color-primary-dark:#06c;--color-accent:#fad75a;--color-text-primary:#000;--color-text-secondary:#666;--color-text-tertiary:#999;--color-bg-primary:#f7f4ee;--color-bg-secondary:#f0ece4;--color-bg-tertiary:#e8e4db;--color-border:#e0e0e0;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b}@supports (color:lab(0% 0 0)){:root,:host{--color-red-500:lab(55.4814% 75.0732 48.8528);--color-amber-500:lab(72.7183% 31.8672 97.9407)}}}@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}html{scroll-behavior:smooth;font-size:18px}html.theme-transitioning,html.theme-transitioning *,html.theme-transitioning :before,html.theme-transitioning :after{transition:background-color .3s,color .2s,border-color .3s,box-shadow .3s!important}body{font-family:var(--font-sans);letter-spacing:.04em;color:var(--color-text-primary);background-color:var(--color-bg-secondary);-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.75}h1,h2,h3,h4{font-weight:700;line-height:1.4}*{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.isolate{isolation:isolate}.z-10{z-index:10}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.my-6{margin-block:calc(var(--spacing) * 6)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.ml-1{margin-left:calc(var(--spacing) * 1)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-dvh{height:100dvh}.max-h-96{max-height:calc(var(--spacing) * 96)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-\[1\%\]{width:1%}.w-\[10\%\]{width:10%}.w-\[12\%\]{width:12%}.w-\[14\%\]{width:14%}.w-\[18\%\]{width:18%}.w-\[28\%\]{width:28%}.w-full{width:100%}.max-w-\[1000px\]{max-width:1000px}.max-w-\[1200px\]{max-width:1200px}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[1\.5rem\]{min-width:1.5rem}.min-w-\[1rem\]{min-width:1rem}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.table-fixed{table-layout:fixed}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-stretch{align-items:stretch}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-12{gap:calc(var(--spacing) * 12)}.gap-16{gap:calc(var(--spacing) * 16)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-border>:not(:last-child)){border-color:var(--color-border)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-t-3{border-top-style:var(--tw-border-style);border-top-width:3px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-\[\#0184ff\]{border-color:#0184ff}.border-border{border-color:var(--color-border)}.border-current{border-color:currentColor}.border-primary{border-color:var(--color-primary)}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab, red, red)){.border-white\/20{border-color:color-mix(in oklab, var(--color-white) 20%, transparent)}}.border-white\/30{border-color:#ffffff4d}@supports (color:color-mix(in lab, red, red)){.border-white\/30{border-color:color-mix(in oklab, var(--color-white) 30%, transparent)}}.border-t-transparent{border-top-color:#0000}.border-l-amber-500{border-left-color:var(--color-amber-500)}.border-l-red-500{border-left-color:var(--color-red-500)}.border-l-text-primary{border-left-color:var(--color-text-primary)}.bg-\[\#0184ff\]{background-color:#0184ff}.bg-\[\#0184ff\]\/15{background-color:#0184ff26;background-color:lab(54.6685% 6.40807 -70.7263/.15)}.bg-\[\#0184ff\]\/80{background-color:#0184ffcc;background-color:lab(54.6685% 6.40807 -70.7263/.8)}.bg-bg-primary{background-color:var(--color-bg-primary)}.bg-primary{background-color:var(--color-primary)}.bg-primary\/5{background-color:#0184ff0d}@supports (color:color-mix(in lab, red, red)){.bg-primary\/5{background-color:color-mix(in oklab, var(--color-primary) 5%, transparent)}}.bg-red-500\/20{background-color:#fb2c3633}@supports (color:color-mix(in lab, red, red)){.bg-red-500\/20{background-color:color-mix(in oklab, var(--color-red-500) 20%, transparent)}}.bg-transparent{background-color:#0000}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-\[1\.2rem\]{padding-inline:1.2rem}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-\[0\.9rem\]{padding-block:.9rem}.text-center{text-align:center}.text-left{text-align:left}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--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-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.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)}.whitespace-nowrap{white-space:nowrap}.text-amber-500{color:var(--color-amber-500)}.text-primary{color:var(--color-primary)}.text-red-500{color:var(--color-red-500)}.text-text-primary{color:var(--color-text-primary)}.text-text-secondary{color:var(--color-text-secondary)}.text-text-tertiary{color:var(--color-text-tertiary)}.text-white{color:var(--color-white)}.text-white\/70{color:#ffffffb3}@supports (color:color-mix(in lab, red, red)){.text-white\/70{color:color-mix(in oklab, var(--color-white) 70%, transparent)}}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline-offset-2{text-underline-offset:2px}.opacity-50{opacity:.5}.shadow-\[var\(--card-shadow\)\]{--tw-shadow:var(--card-shadow);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.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)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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,)}.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))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.hover\:bg-primary:hover{background-color:var(--color-primary)}.hover\:bg-primary-light:hover{background-color:var(--color-primary-light)}.hover\:text-white:hover{color:var(--color-white)}.hover\:underline:hover{text-decoration-line:underline}}@media (min-width:64rem){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.\[\&_p\]\:text-inherit p{color:inherit}.\[\&_table\]\:table-fixed table{table-layout:fixed}.\[\&_tbody_tr\:nth-child\(even\)\]\:bg-bg-secondary\/50 tbody tr:nth-child(2n){background-color:#f0ece480}@supports (color:color-mix(in lab, red, red)){.\[\&_tbody_tr\:nth-child\(even\)\]\:bg-bg-secondary\/50 tbody tr:nth-child(2n){background-color:color-mix(in oklab, var(--color-bg-secondary) 50%, transparent)}}.\[\&\>div\]\:px-3>div{padding-inline:calc(var(--spacing) * 3)}.\[\&\>div\]\:px-7>div{padding-inline:calc(var(--spacing) * 7)}.\[\&\>div\]\:py-2>div{padding-block:calc(var(--spacing) * 2)}.\[\&\>div\]\:py-5>div{padding-block:calc(var(--spacing) * 5)}table[data-variant=compact] .\[table\[data-variant\=\"compact\"\]_\&\]\:px-3{padding-inline:calc(var(--spacing) * 3)}table[data-variant=compact] .\[table\[data-variant\=\"compact\"\]_\&\]\:py-2{padding-block:calc(var(--spacing) * 2)}table[data-variant=comparison] .\[table\[data-variant\=\"comparison\"\]_\&\]\:text-center{text-align:center}}html[data-theme=dark]{--color-text-primary:#efefef;--color-text-secondary:#9a9a9a;--color-text-tertiary:#505050;--color-bg-primary:#111;--color-bg-secondary:#090909;--color-bg-tertiary:#1a1a1a;--color-border:#242424;--card-shadow:0 2px 8px #0006;--card-shadow-hover:0 4px 12px #00000080;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=light]{--color-text-primary:#000;--color-text-secondary:#555;--color-text-tertiary:#888;--color-bg-primary:#fff;--color-bg-secondary:#f0f0e8;--color-bg-tertiary:#e8e8e0;--color-border:#e0e0d8;--card-shadow:0 1px 2px #00000003;--card-shadow-hover:0 1px 2px #00000003;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--text-primary:#000;--text-secondary:#555;--text-muted:#888;--bg-base:#fff;--bg-card:#f5f5ed;--bg-hover:#f0f0e8;--bg-input:#fff;--border:#e0e0d8}html[data-theme=dark] .badge,html[data-theme=dark] .course-card-badge{color:#000}html[data-theme=dark] .prompt-box-copy:hover{background:#ffffff0f}html[data-theme=dark] .skill-card:hover,html[data-theme=dark] .dp-case-card:hover{box-shadow:0 2px 8px #0006}html[data-theme=dark] *{scrollbar-color:var(--color-text-tertiary) transparent}html[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--color-text-tertiary)}html[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.prompt-box-v2__textarea{scrollbar-width:none}.prompt-box-v2__textarea::-webkit-scrollbar{display:none}.app-shell{height:100vh;display:flex;overflow:hidden}.app-main{flex:1;min-width:0;overflow:hidden auto}.view-toggle{z-index:100;border:1px solid var(--border,#2a2a3a);background:var(--bg-card,#141420);border-radius:8px;display:flex;position:fixed;top:1rem;right:1rem;overflow:hidden;box-shadow:0 2px 8px #0006}.view-toggle-btn{color:var(--text-secondary,#8888a0);cursor:pointer;background:0 0;border:none;align-items:center;gap:.375rem;padding:.4rem .875rem;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.view-toggle-btn:hover{color:var(--text-primary,#e8e8f0);background:#ffffff0d}.view-toggle-btn.active{color:#e8e8e8;cursor:default;background:#1e1e1e}.view-toggle-btn>i{font-size:.75rem}.divider-handle .divider-bg{opacity:0;pointer-events:none;position:absolute;inset:0}.divider-handle .divider-line{pointer-events:none;background-color:#ffffff1a;border-radius:9999px;width:1px;transition:background-color 1s linear,width 1s linear}.divider-handle[data-hovering=true] .divider-bg{animation:1s linear forwards divider-fill}.divider-handle[data-hovering=true] .divider-line{background-color:#fff;width:4px}.divider-handle[data-hovering=false] .divider-bg,.divider-handle:not([data-hovering]) .divider-bg{opacity:0;animation:none}@keyframes divider-fill{0%{opacity:0;background-color:#000000b3}to{opacity:1;background-color:#ffffffe6}}.expand-handle{background-color:#ffffff0d}.expand-handle[data-hovering=true]{animation:.4s linear forwards expand-fill}.expand-handle[data-hovering=false],.expand-handle:not([data-hovering]){background-color:#ffffff0d;animation:none}@keyframes expand-fill{0%{background-color:#ffffff0d}to{background-color:#ffffff26}}@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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@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-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-outline-style{syntax:"*";inherits:false;initial-value:solid}@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-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}
.slide-px-indicator{z-index:9999;font-size:.7rem;font-family:var(--font-mono);color:var(--color-text-tertiary);opacity:.6;pointer-events:none;letter-spacing:.03em;font-weight:400;position:fixed;top:8px;right:12px}.course-outer{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.course-fixed-header{background:var(--color-bg-primary);border-bottom:1px solid var(--color-border);z-index:100;flex-shrink:0;align-items:center;height:48px;min-height:48px;padding:0 1rem;display:flex;position:sticky;top:0}.cfh-left{align-items:center;gap:.25rem;display:flex}.cfh-btn{color:var(--color-text-secondary);font-size:.85rem;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:.4rem;padding:.3rem .65rem;font-weight:400;text-decoration:none;transition:all .2s;display:inline-flex}.cfh-btn:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text-primary)}.cfh-btn:disabled{opacity:.4;cursor:not-allowed}.cfh-btn--student{color:var(--color-success,#10b981);border-color:color-mix(in srgb, var(--color-success,#10b981) 50%, transparent)}.cfh-btn--student:hover:not(:disabled){background:color-mix(in srgb, var(--color-success,#10b981) 10%, transparent);color:var(--color-success,#10b981)}.course-wrapper{flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.toc{background:var(--color-bg-primary);width:300px;height:100%;box-shadow:-1px 0 0 0 var(--color-border);flex-direction:column;flex-shrink:0;order:10;transition:width .3s,opacity .3s;display:flex;overflow:hidden}.course-wrapper[data-toc=collapsed] .toc{opacity:0;width:0;overflow:hidden}.toc a{color:var(--color-text-secondary);border-radius:6px;align-items:center;padding:.35rem .75rem;font-size:.85rem;text-decoration:none;transition:all .2s;display:flex;position:relative}.toc a:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.toc a.chapter-link{color:var(--color-text-primary);margin-top:.75rem;font-size:.9rem;font-weight:700}.toc a.active{color:var(--color-primary);background:#0184ff14;font-weight:600}.toc a.chapter-link.active{color:var(--color-primary);background:#0184ff1a}.main-content{scroll-behavior:smooth;flex:1;order:5;min-width:0;padding:2rem 3rem 6rem;overflow:hidden auto}.info-panel{background:var(--color-bg-primary);border-left:1px solid var(--color-border);flex-direction:column;flex-shrink:0;order:99;width:400px;height:100%;transition:width .3s,opacity .3s;display:flex;overflow-y:auto}.info-panel.collapsed{opacity:0;width:0;overflow:hidden}.info-panel-close{cursor:pointer;color:var(--color-text-tertiary);background:0 0;border:none;border-radius:4px;padding:.25rem;font-size:.85rem;transition:all .2s}.info-panel-close:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.info-panel-body{flex:1;padding:1.25rem;overflow-y:auto}.info-panel-empty{height:100%;color:var(--color-text-tertiary);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.info-panel-empty i{opacity:.4;margin-bottom:1rem;font-size:2rem}.info-panel-empty p{margin:0;font-size:.85rem;line-height:1.6}.info-panel-section{margin-bottom:1.25rem}.info-panel-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:.5rem;font-size:.75rem;font-weight:700}.info-panel-content{color:var(--color-text-secondary);white-space:pre-wrap;font-size:.82rem;line-height:1.7;font-family:var(--font-mono);padding:0}.info-panel-note{border-top:1px solid var(--color-border);color:var(--color-text-tertiary);padding:.75rem 0;font-size:.82rem;line-height:1.7}.toc-header{flex-direction:column;gap:.5rem;margin-bottom:.75rem;display:flex}.toc-course-title-btn{border:1px solid var(--color-border);background:var(--color-bg-primary);width:100%;color:var(--color-primary);font-size:.95rem;font-weight:700;font-family:var(--font-sans);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:.5rem .75rem;transition:all .2s;display:flex}.toc-course-title-btn:hover:not(:disabled){border-color:var(--color-primary);background:#0184ff0f}.toc-course-title-btn:disabled{opacity:.5;cursor:not-allowed}.toc-course-title-btn--student{color:var(--color-success,#10b981);border-color:color-mix(in srgb, var(--color-success,#10b981) 50%, transparent);margin-top:.4rem}.toc-course-title-btn--student:hover:not(:disabled){background:color-mix(in srgb, var(--color-success,#10b981) 8%, transparent);border-color:var(--color-success,#10b981)}.toc-ai-icon{opacity:0;font-size:.8rem;transition:opacity .2s}.toc-course-title-btn:hover .toc-ai-icon{opacity:1}.toc-note-icon{color:var(--color-text-muted,#888);opacity:.7;flex-shrink:0;margin-left:auto;font-size:.55rem}.toc-category-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-top:.75rem;padding:.35rem .75rem .1rem;font-size:.72rem;font-weight:700;display:block}.toc-scroll-area{flex:1;padding:1rem;overflow-y:auto}.toc-collapse-btn{border:none;border-bottom:1px solid var(--color-border);height:2.85rem;color:var(--color-text-secondary);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;gap:.4rem;padding:0 .75rem;font-size:.85rem;transition:background .15s,color .15s;display:flex}.toc-collapse-btn:hover{background:var(--color-bg-hover,#ffffff0d);color:var(--color-text-primary)}.toc-copy-prompt{padding:8px 12px 4px}.toc-expand-btn{z-index:150;border:1px solid var(--color-border);background:var(--color-bg-secondary);width:1.75rem;height:3rem;color:var(--color-text-secondary);cursor:pointer;border-right:none;border-radius:6px 0 0 6px;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:flex;position:absolute;top:50%;right:0;transform:translateY(-50%);box-shadow:-2px 0 8px #0003}.toc-expand-btn:hover{background:var(--color-bg-hover,#ffffff0d);color:var(--color-text-primary)}.slide-image{border-radius:8px;max-width:100%;height:auto;margin-top:.75rem}.slide-caption{color:var(--color-text-secondary);margin-top:.75rem;font-size:1rem}.slide-caption--center{text-align:center}.slide-caption--sm{font-size:.85rem}.slide-subtitle{color:var(--color-text-secondary);margin-top:.5rem;font-size:1.05rem}@media (max-width:900px){.main-content{padding:1.5rem}.card-grid-2,.card-grid-3,.comparison{grid-template-columns:1fr}.chat-panel-slot{width:320px}}
.chapter-section{flex-direction:column;margin-bottom:1.5rem;padding-top:1rem;display:flex}.chapter-title{color:var(--color-primary);border-bottom:3px solid var(--color-primary);margin-bottom:2rem;padding-bottom:.75rem;font-size:2rem}.slide{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:1280px;height:720px;margin:3rem auto 2.5rem;padding:2rem;display:flex;position:relative}.slide.slide--fill{justify-content:flex-start;overflow:hidden}.slide--overflow{outline-offset:-2px;outline:2px dashed #ef4444}.slide--overflow:after{content:"⚠ 內容溢出 " attr(data-overflow-px) "px，請拆頁";color:#fff;z-index:50;pointer-events:none;white-space:nowrap;letter-spacing:.02em;background:#ef4444;border-radius:6px;padding:4px 10px;font-size:13px;font-weight:600;position:absolute;top:10px;right:10px}.slide>.slide-header{flex-shrink:0;width:100%;position:absolute;bottom:calc(100% + .5rem);left:0;overflow:visible}.slide>:not(.slide-header):not(.slide-nav-overlay):not(.action-link){width:90%;max-width:900px}.slide-header{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.slide-number{background:var(--color-primary);color:#fff;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;min-width:2.75rem;height:1.75rem;padding:0 .5rem;font-size:.8rem;font-weight:700;display:inline-flex}.slide-label{color:var(--color-text-primary);font-size:1.05rem;font-weight:600}.slide h1{color:var(--color-text-primary);margin:0 0 .75rem;font-size:2rem;font-weight:700;line-height:1.35}.slide h2{color:var(--color-text-primary);margin:0 0 .5rem;font-size:1.6rem;font-weight:700;line-height:1.4}.slide h3{color:var(--color-text-primary);margin:0 0 .5rem;font-size:1.3rem;font-weight:700;line-height:1.45}.slide p:not(.highlight-text){color:var(--color-text-secondary);margin-bottom:1.25rem;font-size:1.2rem;line-height:1.75}.slide p:last-child{margin-bottom:0}.slide a:not(.action-link){color:var(--color-primary);font-weight:500;text-decoration:none;transition:color .2s}.slide a:not(.action-link):hover{color:var(--color-primary-dark);text-decoration:underline}.slide>.action-link{align-self:center}.prompt-box{border:1px solid var(--color-border);border-radius:8px;margin:.75rem 0;position:relative;overflow:hidden}.prompt-box-header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);font-family:var(--font-sans);color:var(--color-text-primary);letter-spacing:.03em;justify-content:space-between;align-items:center;padding:.4rem 1rem;font-size:.8rem;font-weight:600;display:flex}.prompt-box-copy{color:var(--color-text-tertiary);font-size:.75rem;font-family:var(--font-sans);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:.35rem;padding:.15rem .5rem;transition:color .15s,background .15s;display:flex}.prompt-box-copy:hover{color:var(--color-text-primary);background:#0000000a}.prompt-box-copy i{font-size:.7rem}.prompt-box-content{background:var(--color-bg-primary);color:var(--color-text-secondary);font-family:var(--font-sans);white-space:pre-wrap;padding:1rem 1.25rem;font-size:1rem;line-height:1.7}.card-grid{gap:1rem;margin:1.25rem 0;display:grid}.card-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.card-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{border:1px solid var(--color-border);background:var(--color-bg-primary);box-shadow:var(--card-shadow);text-align:left;border-radius:12px;padding:1.25rem 1.5rem;transition:box-shadow .2s}.card:hover{box-shadow:var(--card-shadow-hover)}.card h3{color:var(--color-text-primary);margin:0 0 .75rem;font-size:1.25rem;font-weight:700}.card h4{color:var(--color-text-primary);margin:0 0 .75rem;font-size:1.15rem;font-weight:700}.card h4 i{margin-right:.4rem}.card p{color:var(--color-text-secondary);margin:0;font-size:.875rem;line-height:1.6}.card--centered{text-align:center;padding:1.75rem 1.5rem}.bullet-list{margin:.5rem 0;padding-left:1.5rem}.bullet-list li{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:1.1rem;line-height:1.8}.badge{background:var(--color-accent);color:#000;border-radius:999px;padding:.25rem .75rem;font-size:.8rem;font-weight:700;display:inline-block}.badge-large{padding:.4rem 1.2rem;font-size:1rem}.checkpoint{background:#0184ff0f;border:none;border-radius:8px;align-items:center;gap:.75rem;margin:1.25rem 0;padding:1rem 1.25rem;display:flex}.checkpoint i{color:var(--color-primary);flex-shrink:0;font-size:1.2rem}.checkpoint p{color:var(--color-text-primary);margin:0;font-weight:600}.highlight-text{color:var(--color-text-primary);text-align:center;margin:1rem 0;font-size:2.5rem;font-weight:700;line-height:1.35}.chapter-section>.slide:first-of-type .highlight-text{color:var(--color-primary);font-size:3.5rem}html[data-theme=dark] .chapter-section>.slide:first-of-type .highlight-text{color:var(--color-text-primary)}.notes-large .slide p:not(.highlight-text){font-size:1.5rem;line-height:1.7}.notes-large .slide .slide-caption{font-size:1.5rem;line-height:1.6}.notes-large .slide h2{font-size:2.3rem;line-height:1.3}.notes-large .slide h3{font-size:1.55rem;line-height:1.45}.notes-large .callout-box{padding:1.1rem 1.3rem}.notes-large .callout-box__text{font-size:1.35rem;line-height:1.7}.notes-large .slide th,.notes-large .slide td{font-size:1.25rem;line-height:1.55}.comparison{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1rem;margin:.75rem 0;display:grid}.comparison-item{border:1px solid var(--color-border);background:var(--color-bg-primary);box-shadow:var(--card-shadow);border-radius:12px;padding:1rem}.comparison-item h4{margin-bottom:.3rem;font-size:1.1rem;font-weight:700}.comparison-item p{color:var(--color-text-secondary);margin:0;font-size:1rem;line-height:1.6}.steps{counter-reset:step;margin:.75rem 0;padding-left:0;list-style:none}.steps li{counter-increment:step;color:var(--color-text-secondary);padding:.5rem 0 .5rem 2.5rem;line-height:1.8;position:relative}.steps li:before{content:counter(step);background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:.55rem;left:0}.slide.break-notice{background:var(--color-bg-secondary);justify-content:center}.break-notice p{color:var(--color-text-secondary);text-align:center;margin:0;font-weight:600}.mono-url{font-family:var(--font-mono);word-break:break-all;color:var(--color-text-secondary);font-size:.8rem;line-height:1.6}.mono-url .hl{color:var(--color-primary);font-weight:600}.back-link{color:var(--color-text-secondary);border-radius:6px;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.4rem .75rem;font-size:.85rem;text-decoration:none;transition:all .2s;display:inline-flex}.back-link:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.action-badge{background:var(--color-primary);color:#fff;letter-spacing:.02em;border-radius:10px;align-items:center;gap:.6rem;margin:.5rem 0;padding:.75rem 1.4rem;font-size:1.1rem;font-weight:700;display:inline-flex;box-shadow:0 4px 16px #0184ff33}.action-badge--sm{padding:.45rem 1rem;font-size:.9rem}.action-badge--lg{padding:1rem 1.8rem;font-size:1.3rem}.action-badge i{font-size:.95rem}.action-link{background:var(--color-primary);color:#fff;border-radius:10px;align-self:flex-start;align-items:center;gap:.5rem;margin-top:.75rem;padding:.6rem 1.2rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex;box-shadow:0 1px 3px #00000014}.action-link:hover{background:var(--color-primary-light,#33a1ff);color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px #0184ff33}.slide-table{border-collapse:separate;border-spacing:0;border:1px solid var(--color-border);border-radius:10px;width:100%;margin:1.25rem 0;font-size:.95rem;overflow:hidden}.slide-table thead tr{background:var(--color-primary)}.slide-table th{text-align:left;color:#fff;letter-spacing:.02em;padding:.75rem 1rem;font-size:.9rem;font-weight:700}.slide-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-primary);padding:.75rem 1rem}.slide-table tbody tr:last-child td{border-bottom:none}.slide-table tbody tr:hover{background:#0184ff0a}.class-intro{gap:1.25rem;width:100%;margin-top:.5rem;display:flex}.class-intro .slide-table{flex:1;margin-top:0}.class-intro .slide-table td:first-child,.class-intro .slide-table th:first-child{white-space:nowrap}.slide-table-row--active td{background:#0184ff14;font-weight:700;color:var(--color-primary)!important}.callout-box{background:var(--callout-bg,#0184ff14);border:1px solid var(--callout-border,#0184ff2e);border-radius:10px;align-items:flex-start;gap:.65rem;margin-top:.75rem;padding:.75rem 1rem;display:flex}.callout-box__icon{color:var(--callout-color,var(--color-primary));flex-shrink:0;margin-top:1px}.callout-box__text{color:var(--color-text-primary);font-size:.9rem;line-height:1.5}.callout-box--info{--callout-color:var(--color-primary);--callout-bg:#0184ff14;--callout-border:#0184ff2e}.callout-box--success{--callout-color:#22c55e;--callout-bg:#22c55e14;--callout-border:#22c55e33}.callout-box--warning{--callout-color:#f59e0b;--callout-bg:#f59e0b14;--callout-border:#f59e0b33}.slide-action-btn{background:var(--color-primary);color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;font-family:var(--font-sans);border:none;border-radius:10px;align-items:center;gap:.5rem;margin-top:.5rem;padding:.6rem 1.2rem;transition:all .2s;display:inline-flex;box-shadow:0 1px 3px #00000014}a.slide-action-btn{color:#fff;text-decoration:none}.slide-action-btn:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #0184ff33}.slide-action-btn.active{background:var(--color-primary-dark);box-shadow:0 0 0 2px #0184ff4d}.modal-overlay{z-index:9999;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-dialog{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:.75rem;width:90%;max-width:860px;max-height:85vh;padding:1.5rem;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-close{cursor:pointer;color:var(--color-text-tertiary);background:0 0;border:none;border-radius:4px;padding:.25rem;font-size:1.1rem;transition:all .2s}.modal-close:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.icon-primary{color:var(--color-primary)}.icon-success{color:var(--color-success)}.icon-error{color:var(--color-error)}.icon-warning{color:var(--color-warning)}.icon-muted{color:var(--color-text-tertiary)}.drink-order-root{width:100%;padding:1rem 0}.drink-order-main{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:1.5rem;display:grid}.drink-order-form-section,.drink-order-list-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:16px;padding:1.5rem}.drink-order-label{color:var(--color-text-secondary);margin-bottom:1rem;font-size:.95rem;font-weight:500;display:block}.drink-order-input{border:1px solid var(--color-border);background:var(--color-bg-tertiary);width:100%;color:var(--color-text-primary);border-radius:10px;margin-top:.35rem;padding:.6rem .75rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.drink-order-input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #1a5f4a1f}.drink-order-option-group{flex-wrap:wrap;gap:.5rem;margin-top:.35rem;margin-bottom:1rem;display:flex}.drink-order-option-btn{border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:pointer;border-radius:10px;padding:.5rem 1rem;font-size:.95rem;transition:background .2s,border-color .2s,color .2s}.drink-order-option-btn:hover{color:#1a5f4a;background:#1a5f4a14;border-color:#1a5f4a}.drink-order-option-btn.selected:hover{color:#fff;background:#14503e;border-color:#14503e}.drink-order-option-btn.selected{color:#fff;background:#1a5f4a;border-color:#1a5f4a}.drink-order-submit{color:#fff;cursor:pointer;background:#1a5f4a;border:none;border-radius:10px;width:100%;margin-top:.75rem;padding:.7rem 1.4rem;font-size:1rem;font-weight:600;transition:background .2s,transform .1s}.drink-order-submit:hover{background:#14503e}.drink-order-submit:active{transform:scale(.99)}@keyframes drink-dots{0%{content:"."}33%{content:".."}66%{content:"..."}}.drink-order-dots:after{content:".";animation:1s step-end infinite drink-dots}.drink-order-submit.submitting{pointer-events:none;opacity:.85}.drink-order-submit.success{background:var(--color-success)}.drink-order-list-section{max-height:400px;overflow-y:auto}.drink-order-loading{color:var(--color-text-tertiary);margin:0;font-size:.95rem}.drink-order-error{color:var(--color-error);margin-top:.5rem;font-size:.9rem}.drink-order-list{margin:0;padding:0;list-style:none}.drink-order-list li{border-bottom:1px solid var(--color-border);grid-template-columns:1fr auto;align-items:baseline;gap:.3rem 1rem;padding:.85rem 0;display:grid}.drink-order-list li:last-child{border-bottom:none}.drink-order-list li:first-child{padding-top:0}.drink-order-name{color:var(--color-text-primary);grid-column:1;font-weight:600}.drink-order-detail{color:var(--color-text-secondary);grid-column:1/-1;font-size:.9rem}.drink-order-time{color:var(--color-text-tertiary);grid-area:1/2;font-size:.8rem}@media (max-width:480px){.drink-order-main{grid-template-columns:1fr}}.showcase-game-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem;width:100%;display:grid}.showcase-game-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}.showcase-game-card{border:1px solid var(--color-border);background:var(--color-bg-primary);border-radius:14px;flex-direction:column;min-height:380px;display:flex;overflow:hidden}.showcase-game-title{color:#fff;background:var(--color-primary);letter-spacing:.03em;padding:.65rem 1rem;font-size:.85rem;font-weight:700}.showcase-game-body{flex-direction:column;flex:1;gap:.75rem;padding:1rem;display:flex}.showcase-game-desc{color:var(--color-text-secondary);text-align:center;margin:0;font-size:.85rem}.showcase-game-counter{color:var(--color-text-tertiary);text-align:center;margin:0;font-size:.75rem}.showcase-game-question{color:var(--color-text-primary);text-align:center;margin:0;font-size:.9rem;font-weight:600;line-height:1.5}.showcase-game-mood-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.5rem;display:grid}.showcase-game-mood-btn{border:1.5px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;font-family:var(--font-sans);border-radius:10px;flex-direction:column;align-items:center;gap:.2rem;padding:.6rem 0;transition:all .2s;display:flex}.showcase-game-mood-btn:hover{border-color:var(--color-primary);background:var(--color-bg-secondary);color:var(--color-text-primary)}.showcase-game-mood-btn.active{border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 10%, transparent);color:var(--color-primary)}.showcase-game-mood-emoji{font-size:1.4rem}.showcase-game-quote{background:color-mix(in srgb, var(--color-primary) 6%, transparent);border:1px solid color-mix(in srgb, var(--color-primary) 20%, transparent);border-radius:10px;flex-direction:column;flex:1;gap:.5rem;padding:.75rem;display:flex}.showcase-game-quote p{color:var(--color-text-primary);flex:1;margin:0;font-size:.85rem;line-height:1.6}.showcase-game-options{flex-direction:column;gap:.5rem;display:flex}.showcase-game-option-btn{border:1.5px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-primary);cursor:pointer;text-align:left;font-size:.85rem;font-weight:500;font-family:var(--font-sans);border-radius:10px;padding:.55rem .75rem;transition:all .2s}.showcase-game-option-btn:hover{border-color:var(--color-primary);background:var(--color-bg-secondary)}.showcase-game-yesno{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.5rem;margin-top:auto;display:grid}.showcase-game-option-btn.yes:hover{border-color:var(--color-success);background:color-mix(in srgb, var(--color-success) 8%, transparent)}.showcase-game-option-btn.no:hover{border-color:var(--color-error);background:color-mix(in srgb, var(--color-error) 8%, transparent)}.showcase-game-result{text-align:center;justify-content:center;align-items:center;gap:.6rem}.showcase-game-score-display{color:var(--color-primary);font-size:2.5rem;font-weight:700;line-height:1}.showcase-game-score-display span{color:var(--color-text-tertiary);font-size:1.1rem;font-weight:400}.showcase-game-sleep-icon{font-size:2rem}.showcase-game-sleep-label{color:var(--color-text-primary);margin:0;font-size:1rem;font-weight:700}.showcase-game-reset{border:1.5px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;font-family:var(--font-sans);background:0 0;border-radius:8px;align-self:center;padding:.5rem 1.2rem;transition:all .2s}.showcase-game-reset:hover{border-color:var(--color-primary);color:var(--color-primary)}.vibe-demo-btn{border:1px solid var(--color-border,#3f3f46);color:inherit;font-family:var(--font-sans);cursor:pointer;background:0 0;border-radius:999px;padding:.55rem 1.1rem;font-size:.95rem;transition:border-color .2s,color .2s,background .2s,transform .1s}.vibe-demo-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.vibe-demo-btn:active{transform:scale(.97)}.flip-grid{grid-template-columns:repeat(2,minmax(220px,1fr));gap:1rem;margin:1rem 0;display:grid}.flip-card{border:1px solid var(--color-border,#3f3f46);min-height:140px;color:inherit;font-family:var(--font-sans);text-align:left;cursor:pointer;background:0 0;border-radius:.75rem;padding:1.1rem 1.2rem;transition:border-color .25s,background .25s,transform .15s;position:relative}.flip-card:hover{border-color:var(--color-primary)}.flip-card:active{transform:scale(.98)}.flip-card--good{background:#22c55e1a;border-color:#22c55e}.flip-card--bad{background:#ef44441a;border-color:#ef4444}.flip-card__face{flex-direction:column;gap:.55rem;height:100%;display:flex}.flip-card__face--back{justify-content:space-between}.flip-card__scenario{font-size:.98rem;line-height:1.55}.flip-card__cue{color:var(--color-text-secondary,#a1a1aa);letter-spacing:.04em;font-size:.78rem}.flip-card__verdict{letter-spacing:.06em;font-size:.85rem;font-weight:600}.flip-card--good .flip-card__verdict{color:#22c55e}.flip-card--bad .flip-card__verdict{color:#ef4444}.flip-card__insight{font-size:.95rem;line-height:1.6}.sftd-root{grid-template-columns:minmax(0,1fr) 48px minmax(0,1fr);align-items:start;gap:.5rem;width:100%;padding:.25rem 0;display:grid}.sftd-panel{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:14px;min-height:200px;padding:1.25rem 1.5rem}.sftd-panel-label{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0 0 1rem;font-size:.78rem;font-weight:600}.sftd-form{flex-direction:column;gap:.75rem;display:flex}.sftd-label{color:var(--color-text-secondary);flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:500;display:flex}.sftd-input{border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-primary);border-radius:9px;padding:.55rem .75rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.sftd-input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f126}.sftd-submit{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:9px;margin-top:.25rem;padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;transition:background .2s,transform .1s}.sftd-submit:hover{background:#4f46e5}.sftd-submit:active{transform:scale(.99)}.sftd-submit.saving{opacity:.75;pointer-events:none}.sftd-submit.saved{background:#16a34a}.sftd-option-group{flex-wrap:wrap;gap:.5rem;margin-top:.35rem;display:flex}.sftd-option-btn{border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:pointer;border-radius:9px;padding:.45rem 1rem;font-size:.9rem;transition:background .2s,border-color .2s,color .2s}.sftd-option-btn:hover{color:#6366f1;background:#6366f114;border-color:#6366f1}.sftd-option-btn.selected{color:#fff;background:#6366f1;border-color:#6366f1}.sftd-arrow{color:var(--color-text-tertiary);justify-content:center;align-items:center;padding-top:5rem;display:flex}.sftd-empty{color:var(--color-text-tertiary);margin:0;padding-top:.5rem;font-size:.9rem}.sftd-table{border-collapse:collapse;width:100%;font-size:.9rem}.sftd-table th{text-align:left;color:var(--color-text-tertiary);border-bottom:1px solid var(--color-border);padding:0 .75rem .6rem;font-size:.8rem;font-weight:600}.sftd-table td{color:var(--color-text-primary);border-bottom:1px solid var(--color-border);vertical-align:middle;padding:.55rem .75rem}.sftd-table tr:last-child td{border-bottom:none}@keyframes sftd-flash{0%{background:#6366f140}to{background:0 0}}.sftd-row-new td{animation:.9s ease-out forwards sftd-flash}.sfs-scope .onb-table th:nth-child(2),.sfs-scope .onb-table td:nth-child(2){white-space:nowrap;padding-inline:2.2rem}
.home-page{background:#fff;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;display:flex}.home-hero{text-align:center;max-width:600px;margin-bottom:3rem}.home-hero-badge{color:#0184ff;letter-spacing:.02em;background:#0184ff14;border:1px solid #0184ff26;border-radius:999px;margin-bottom:1.5rem;padding:.375rem 1rem;font-size:.75rem;font-weight:600;display:inline-block}.home-hero-title{color:#000;margin:0 0 1rem;font-size:2.5rem;font-weight:800;line-height:1.3}.home-accent{color:#0184ff}.home-hero-subtitle{color:#333;margin:0 0 .75rem;font-size:1.125rem;font-weight:600}.home-hero-desc{color:#666;margin:0 0 2rem;font-size:.9375rem;line-height:1.7}.home-hero-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.home-btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.home-btn.primary{color:#fff;background:#0184ff}.home-btn.primary:hover{background:#06c;box-shadow:0 4px 16px #0184ff4d}.home-btn.secondary{color:#666;background:0 0;border:1px solid #e0e0e0}.home-btn.secondary:hover{color:#0184ff;border-color:#0184ff}@media (max-width:640px){.home-hero-title{font-size:1.75rem}}.home-footer{color:#999;gap:1rem;font-size:.75rem;display:flex}.home-footer a{color:#999;text-decoration:none;transition:color .15s}.home-footer a:hover{color:#0184ff}.landing{padding:2rem}.landing-section{margin-bottom:2.5rem}.landing-section-header{border-bottom:1px solid var(--color-border,#2a2a3a);gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;flex-direction:row!important;align-items:center!important;display:flex!important}.landing-section-header>i{color:var(--color-primary,#6366f1);text-align:center;flex-shrink:0;width:1.5rem;font-size:1.1rem}.landing-section-header h3{color:var(--color-text-primary,#e8e8f0);margin:0;font-size:1.1rem;font-weight:700}.landing-section-header p{color:var(--color-text-secondary,#8888a0);margin:.1rem 0 0;font-size:.8rem}.course-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.course-card{grid-template-rows:auto 1fr;gap:.5rem;display:grid}.course-card-slug-zone{align-items:center;padding:0 .25rem;display:flex}.course-card-body{color:inherit;background:#1f1f2c;border:1px solid #4a4a5a;border-radius:12px;gap:.75rem;padding:1.5rem;text-decoration:none;transition:border-color .18s;display:grid}.course-card-body:hover{border-color:var(--color-primary,#0184ff)}.slug-copy-badge{appearance:none;cursor:pointer;font:inherit;min-height:32px;color:inherit;background:#7dd3fc14;border:1px solid #7dd3fc40;border-radius:6px;align-items:center;gap:6px;width:fit-content;padding:8px 12px;line-height:1;transition:border-color .15s,background .15s,box-shadow .15s;display:inline-flex}.slug-copy-badge:hover{background:#7dd3fc2e;border-color:#7dd3fc99}.slug-copy-badge-code{color:#7dd3fc;font-size:.78rem;line-height:1;font-family:var(--font-mono,ui-monospace, monospace);pointer-events:none;white-space:nowrap;background:0 0;padding:0}.slug-copy-badge-icon{color:#7dd3fc;pointer-events:none;align-items:center;display:inline-flex}.slug-copy-badge.is-copied{background:#22c55e1f;border-color:#22c55e73}.slug-copy-badge.is-copied .slug-copy-badge-code,.slug-copy-badge.is-copied .slug-copy-badge-icon{color:#22c55e}.course-card-title-row{align-items:center;gap:.75rem;display:flex}.course-card-title-row h2{margin:0;font-size:1.125rem;font-weight:700}.course-card-badge{background:var(--color-accent,#fad75a);color:#000;text-align:center;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:.15rem .6rem;font-size:.7rem;font-weight:700;display:inline-flex}.course-card-desc{color:var(--text-secondary,#8888a0);margin:0;font-size:.925rem;line-height:1.6}.course-grid-divider{grid-column:1/-1;margin:1rem 0 -.25rem}.course-grid-divider:first-child{margin-top:0}.course-grid-divider-label{letter-spacing:.08em;color:var(--color-text-secondary,#8888a0);font-size:.875rem;font-weight:700}.course-card-meta{color:var(--color-text-tertiary,#555570);gap:1rem;font-size:.8rem;display:flex}
.skill-section{margin-bottom:3rem}.skill-section-header{text-align:center;margin-bottom:1.5rem}.skill-section-header i{color:var(--color-primary);margin-bottom:.5rem;font-size:1.5rem;display:block}.skill-section-header h2{color:var(--color-text-primary);margin:0 0 .25rem;font-size:1.5rem}.skill-section-header p{color:var(--color-text-tertiary);margin:0;font-size:.85rem}.skill-group-title{color:var(--color-text-secondary);align-items:center;gap:.5rem;margin:1.25rem 0 .75rem;font-size:1rem;font-weight:600;display:flex}.skill-group-title i{color:var(--color-text-tertiary);font-size:.85rem}.skill-card{background:var(--color-bg-primary);border:1px solid var(--color-border);cursor:pointer;text-align:left;font-family:var(--font-sans);border-radius:8px;align-items:center;gap:.75rem;width:100%;padding:1rem;transition:all .2s;display:flex}.skill-card:hover{border-color:var(--color-primary);box-shadow:0 2px 12px #0184ff1a}.skill-card-active{border-color:var(--color-primary);box-shadow:0 0 0 2px #0184ff4d}.skill-card-icon{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:1rem;display:flex}.skill-card-body{flex:1;min-width:0}.skill-card-tag{font-size:.7rem;font-weight:600;font-family:var(--font-mono,monospace);letter-spacing:.02em;color:var(--color-text-tertiary);margin-bottom:.15rem;display:block}.skill-card-body h4{color:var(--color-text-primary);margin:0 0 .15rem;font-size:.9rem;font-weight:600}.skill-card-body p{color:var(--color-text-tertiary);margin:0;font-size:.78rem;line-height:1.4}.skill-card-arrow{color:var(--color-text-tertiary);flex-shrink:0;font-size:.75rem;transition:color .2s}.skill-card:hover .skill-card-arrow{color:var(--color-primary)}.skills-toc-group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin:.25rem 0 .4rem .25rem;font-size:.68rem;font-weight:700}.skills-toc-item{cursor:pointer;text-align:left;width:100%;font-family:var(--font-sans);color:var(--color-text-secondary);background:0 0;border:none;border-radius:6px;align-items:center;gap:.6rem;margin-bottom:.1rem;padding:.45rem .6rem;font-size:.85rem;transition:background .15s,color .15s;display:flex}.skills-toc-item:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.skills-toc-item.active{color:var(--color-primary);background:#0184ff14;font-weight:600}.skills-toc-icon{color:#fff;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.7rem;display:flex}.skills-toc-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.skills-detail{max-width:720px;padding:2.5rem 3rem}.skills-detail-header{border-bottom:1px solid var(--color-border);align-items:flex-start;gap:1.25rem;margin-bottom:2.5rem;padding-bottom:1.5rem;display:flex}.skills-detail-icon{color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;font-size:1.4rem;display:flex}.skills-detail-title{color:var(--color-text-primary);margin:0 0 .3rem;font-size:1.6rem;font-weight:700}.skills-detail-desc{color:var(--color-text-secondary);margin:0 0 .4rem;font-size:.88rem;line-height:1.5}.skills-detail-tag{font-size:.72rem;font-weight:600;font-family:var(--font-mono,monospace);color:var(--color-text-tertiary);background:var(--color-bg-secondary);border-radius:4px;padding:.15rem .5rem}.skills-detail-section{margin-bottom:1.75rem}.skills-note{color:var(--color-text-secondary);background:#0184ff14;border:1px solid #0184ff2e;border-radius:8px;align-items:flex-start;gap:.6rem;margin-bottom:1.25rem;padding:.85rem 1rem;font-size:.88rem;line-height:1.6;display:flex}.skills-note i{color:var(--color-primary);flex-shrink:0;margin-top:.2rem;font-size:.9rem}.skills-section-label-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.skills-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);font-size:.72rem;font-weight:700}.skills-copy-btn{font-size:.75rem;font-weight:600;font-family:var(--font-sans);color:var(--color-text-tertiary);background:var(--color-bg-secondary);border:1px solid var(--color-border);cursor:pointer;border-radius:5px;align-items:center;gap:.35rem;padding:.3rem .7rem;transition:all .15s;display:flex}.skills-copy-btn:hover{color:var(--color-primary);border-color:var(--color-primary);background:#0184ff0f}.skills-copy-btn.copied{color:#10b981;background:#10b9810f;border-color:#10b981}.skills-prompt{color:var(--color-text-secondary);white-space:pre-wrap;font-size:.85rem;line-height:1.8;font-family:var(--font-mono,monospace);padding:1.25rem 1.5rem}
.data-processing-landing{max-width:900px;margin:0 auto;padding:3rem 2rem 6rem}.dp-header{margin-bottom:3rem}.dp-header h1{color:var(--color-primary);margin-bottom:.5rem;font-size:2rem}.dp-header p{color:var(--color-text-secondary);font-size:1rem}.dp-categories{flex-direction:column;gap:2.5rem;display:flex}.dp-category h2{margin-bottom:.25rem;font-size:1.3rem}.dp-category-desc{color:var(--color-text-secondary);margin-bottom:1rem;font-size:.85rem}.dp-case-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.dp-case-card{background:var(--color-bg-primary);border:1px solid var(--color-border);color:inherit;border-radius:10px;padding:1.25rem;text-decoration:none;transition:all .2s;display:block}.dp-case-card:hover{border-color:var(--color-primary);box-shadow:0 2px 12px #0184ff1a}.dp-case-card h3{margin-bottom:.35rem;font-size:1rem}.dp-case-card p{color:var(--color-text-secondary);margin:0;font-size:.82rem;line-height:1.6}.data-processing-case{max-width:1100px;margin:0 auto;padding:3rem 2rem 6rem}.dp-case-header{margin-bottom:2.5rem}.dp-case-breadcrumb{color:var(--color-text-tertiary);margin-bottom:.25rem;font-size:.82rem}.dp-case-header h1{color:var(--color-text-primary);margin-bottom:.5rem;font-size:1.75rem}.dp-case-header>p:last-child{color:var(--color-text-secondary);font-size:.95rem}.dp-case-body h2{color:var(--color-text-primary);font-size:1.3rem}@media (max-width:640px){.dp-case-grid{grid-template-columns:1fr}}
:root{--bg-base:#f7f4ee;--bg-card:#f0ece4;--bg-hover:#e8e4db;--bg-input:#fff;--border:#e0e0e0;--text-primary:#1a1a1a;--text-secondary:#666;--text-muted:#999}html[data-theme=dark]{--bg-base:#000;--bg-card:#0d0d0d;--bg-hover:#141414;--bg-input:#111;--border:#1c1c1c;--text-primary:#e8e8e8;--text-secondary:#888;--text-muted:#444}.theme-toggle-floating{z-index:200;border:1px solid var(--border);background:var(--bg-card);width:2rem;height:2rem;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex;position:fixed;top:.75rem;right:.75rem;box-shadow:0 2px 8px #0000001f}.theme-toggle-floating:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-shell{background:var(--bg-base);min-height:100vh;display:flex}.admin-main{flex:1;max-width:1200px;padding:2rem;overflow-y:auto}.admin-nav{background:var(--bg-base);flex-direction:column;flex-shrink:0;width:220px;height:100vh;min-height:100vh;padding:1.25rem .75rem;line-height:1.75;display:flex;position:sticky;top:0}.admin-nav-brand{border-bottom:1px solid var(--border);color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.75rem;padding:0 .5rem 1.25rem;font-size:1rem;font-weight:700;display:flex}.admin-nav-brand>i{color:var(--text-primary);font-size:1.125rem}.admin-nav-badge{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:.125rem .375rem;font-size:.625rem;font-weight:600}.admin-nav-items{flex-direction:column;flex:1;gap:.125rem;display:flex}.admin-nav-item{color:var(--text-secondary);border-radius:8px;align-items:center;gap:.625rem;padding:.625rem .75rem;font-size:.875rem;text-decoration:none;transition:all .15s;display:flex}.admin-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-item.active{color:var(--text-primary);background:#0000000f}html[data-theme=dark] .admin-nav-item.active{color:#e8e8e8;background:#ffffff12}.admin-nav-item>i{text-align:center;width:18px;font-size:.875rem}.admin-nav-section{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:.625rem .75rem .25rem;font-size:.625rem;font-weight:600}.admin-nav-sep{background:var(--border);flex-shrink:0;height:1px;margin:.375rem .75rem}.admin-nav-divider{border-top:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:.375rem;padding:.75rem .75rem .375rem;font-size:.625rem;font-weight:600}.admin-nav-logout{color:var(--text-muted);cursor:pointer;border:none;border-top:1px solid var(--border);background:0 0;border-radius:8px;align-items:center;gap:.625rem;margin-top:.5rem;padding:1rem .75rem .625rem;font-size:.8125rem;transition:all .15s;display:flex}.admin-nav-logout:hover{color:#ef4444}.admin-page-header{margin-bottom:2rem}.admin-page-header h1{color:var(--text-primary);margin:0 0 .375rem;font-size:1.5rem;font-weight:700}.admin-page-header p{color:var(--text-secondary);margin:0;font-size:.875rem}.admin-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;align-items:center;gap:1rem;padding:1.25rem;text-decoration:none;transition:border-color .2s;display:flex}.admin-stat-card:hover{border-color:#444}.admin-stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;display:flex}.admin-stat-icon.purple{color:#888;background:#ffffff0f}.admin-stat-icon.green{color:#22c55e;background:#22c55e1f}.admin-stat-icon.amber{color:#f59e0b;background:#f59e0b1f}.admin-stat-icon.blue{color:#3b82f6;background:#3b82f61f}.admin-stat-content h3{color:var(--text-secondary);margin:0 0 .25rem;font-size:.8125rem;font-weight:500}.admin-stat-content .admin-stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.docs-page{max-width:860px;margin:0 auto;padding-top:2rem}.docs-page-wide{padding:2rem 1.5rem}.docs-page-comfortable{max-width:960px}.docs-page-comfortable .docs-section p,.docs-page-comfortable .docs-section li{line-height:1.8}.docs-grid-2{grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem;display:grid}.docs-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:1.25rem;padding:2rem 2rem 1.5rem}.docs-section h1{color:var(--text-primary);margin:0 0 .375rem;font-size:1.375rem;font-weight:700;line-height:1.3}.docs-section h1+p{color:var(--text-secondary);margin:0 0 1.5rem;font-size:.9rem}.docs-section h2{color:var(--text-primary);border-bottom:1px solid var(--border);align-items:center;gap:.5rem;margin:2rem 0 .75rem;padding-bottom:.5rem;font-size:1rem;font-weight:700;display:flex}.docs-section h2:first-child{margin-top:0}.docs-section h2>i{color:#666;font-size:1rem}.docs-section h3{color:var(--text-primary);align-items:center;gap:.375rem;margin:1.25rem 0 .5rem;font-size:.875rem;font-weight:600;display:flex}.docs-section h3:before{content:"";background:var(--color-primary,#0184ff);border-radius:2px;flex-shrink:0;width:3px;height:.875rem;display:inline-block}.docs-section hr{border:none;border-top:1px solid var(--border);margin:1.75rem 0}.docs-section p,.docs-section li{color:var(--text-secondary);font-size:.875rem;line-height:1.65}.docs-section ul{margin:.5rem 0;padding-left:1.25rem}.docs-section ol{counter-reset:none;margin:.5rem 0;padding-left:1.5rem}.docs-section ol li{margin-bottom:.375rem}.docs-section li{margin-bottom:.25rem}.docs-section code{background:var(--bg-input);color:#aaa;border-radius:4px;padding:.125rem .375rem;font-family:IBM Plex Mono,monospace;font-size:.8125rem}.docs-section pre{background:var(--bg-input);border:1px solid var(--border);border-radius:8px;margin:.75rem 0;padding:1rem 1.25rem;overflow-x:auto}.docs-section pre code{color:var(--text-secondary);background:0 0;padding:0;font-size:.8125rem;line-height:1.7}.docs-section blockquote{border-left:3px solid var(--color-primary,#0184ff);background:color-mix(in srgb, var(--color-primary,#0184ff) 8%, transparent);border-radius:0 6px 6px 0;margin:1rem 0;padding:.625rem 1rem}.docs-section blockquote p{color:var(--text-secondary);margin:0;font-size:.8125rem}.docs-section table{border-collapse:collapse;width:100%;margin:.75rem 0;font-size:.8125rem}.docs-section th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);text-align:left;padding:.5rem .75rem;font-size:.75rem;font-weight:600}.docs-section td{color:var(--text-primary);border-bottom:1px solid var(--border);padding:.5rem .75rem}.docs-section td code{background:var(--bg-input);color:#aaa;border-radius:4px;padding:.125rem .375rem;font-size:.8125rem}.docs-section strong{color:var(--text-primary);font-weight:600}.docs-flow{background:var(--bg-input);color:var(--text-secondary);white-space:pre;border-radius:8px;padding:1rem 1.25rem;font-family:IBM Plex Mono,monospace;font-size:.8125rem;line-height:1.7;overflow-x:auto}.docs-table{border-collapse:collapse;width:100%;margin:.75rem 0;font-size:.8125rem}.docs-table th,.docs-table td{text-align:left;border-bottom:1px solid var(--border);padding:.5rem .75rem}.docs-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.docs-table td{color:var(--text-primary)}.docs-table td code{background:var(--bg-input);color:#aaa;border-radius:4px;padding:.125rem .375rem;font-size:.8125rem}.docs-badge{text-transform:uppercase;border-radius:4px;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;display:inline-block}.docs-badge.live{color:#22c55e;background:#22c55e1f}.docs-badge.wip{color:#3b82f6;background:#3b82f61f}.docs-badge.ended{color:#888;background:#ffffff0f}.docs-badge.skip{color:#555;background:#ffffff0a;text-decoration:line-through}.docs-badge.defer{color:#9b7de8;background:#7850c81a}.docs-badge.admin{color:#f59e0b;background:#f59e0b1f}.docs-badge.student{color:#3b82f6;background:#3b82f61f}.kanban-board{gap:.75rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.kanban-column{background:#ffffff05;border-radius:10px;flex-direction:column;flex:1;gap:.5rem;min-width:220px;padding:.6rem;display:flex}.kanban-column.drag-over{background:#3b82f60f;outline:1px dashed #3b82f64d}.kanban-column-header{color:#ccc;align-items:center;gap:.4rem;padding:.25rem .25rem .5rem;font-size:.82rem;font-weight:600;display:flex}.kanban-column-count{color:#666;font-size:.7rem;font-weight:400}.kanban-card{cursor:grab;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;padding:.65rem .75rem;transition:transform .1s,box-shadow .15s;position:relative}.kanban-card:hover{background:#ffffff14;box-shadow:0 2px 8px #0000004d}.kanban-card:active{cursor:grabbing}.kanban-card.dragging{opacity:.3}.kanban-card-title{margin-bottom:.2rem;padding-right:1.2rem;font-size:.8rem;font-weight:600}.kanban-card-desc{color:#888;font-size:.7rem;line-height:1.4}.kanban-card-delete{color:#555;cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;transition:opacity .15s,background .15s,color .15s;display:flex;position:absolute;top:.45rem;right:.45rem}.kanban-card:hover .kanban-card-delete{opacity:1}.kanban-card-delete:hover{color:#ef4444;background:#ef444433}.kanban-priority{border-radius:4px;margin-top:.4rem;padding:1px 6px;font-size:.62rem;font-weight:600;display:inline-block}.kanban-priority.high{color:#ef4444;background:#ef444426}.kanban-priority.mid{color:#f59e0b;background:#f59e0b26}.kanban-priority.low{color:#9ca3af;background:#9ca3af26}.kanban-priority.ref{color:#63b3ed;background:#63b3ed26}.admin-nav-version{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border);white-space:nowrap;border-radius:4px;align-items:center;gap:.25rem;margin-left:auto;padding:.125rem .375rem;font-family:IBM Plex Mono,monospace;font-size:.625rem;font-weight:600;text-decoration:none;transition:background .15s;display:flex}.admin-nav-version:hover{background:var(--bg-hover);color:var(--text-secondary)}.admin-nav-footer{border-top:1px solid var(--border);margin-top:auto;padding-top:.75rem}.admin-nav-collapse-btn{border:none;border-bottom:1px solid var(--border);background:var(--bg-base);cursor:pointer;height:2.4rem;color:var(--text-secondary);z-index:5;border-radius:0;flex-shrink:0;justify-content:center;align-items:center;gap:.4rem;margin:-1.25rem -.75rem .75rem;padding:0 .75rem;font-size:.85rem;transition:background .15s,color .15s;display:flex;position:sticky;top:0}.admin-nav-collapse-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-pack-btn{cursor:pointer;width:100%;color:var(--text-secondary);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.625rem;padding:.625rem .75rem;font-size:.875rem;transition:all .15s;display:flex}.admin-nav-pack-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-pack-btn.open{color:#f59e0b;background:#f59e0b1a}.admin-nav-pack-btn.running{color:#f59e0b}.admin-nav-pack-btn>i{text-align:center;width:18px;font-size:.875rem}.admin-nav-pack-phase{color:#f59e0b;opacity:.7;margin-left:auto;font-family:IBM Plex Mono,monospace;font-size:.625rem}.admin-nav-debug-btn{cursor:pointer;width:100%;color:var(--text-muted);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.625rem;margin-bottom:.25rem;padding:.5rem .75rem;font-family:IBM Plex Mono,monospace;font-size:.75rem;transition:all .15s;display:flex}.admin-nav-debug-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.admin-nav-debug-btn.active{color:#58a6ff;background:#58a6ff1a}.admin-nav-debug-btn>i{text-align:center;width:18px;font-size:.75rem}.admin-nav-debug-pulse{background-color:#58a6ff;border-radius:50%;width:6px;height:6px;margin-left:auto;animation:1.5s ease-in-out infinite debug-pulse}@keyframes debug-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.admin-page{max-width:900px;margin-left:auto;margin-right:auto;padding:2rem}.changelog-tag{text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-radius:4px;padding:.125rem .375rem;font-size:.625rem;font-weight:700;display:inline-block}.changelog-tag.prod{color:#60a5fa;background:#3b82f626;border:1px solid #3b82f64d}.changelog-tag.dev{color:#4ade80;background:#22c55e26;border:1px solid #22c55e4d}@keyframes changelog-ping{0%,to{opacity:.3;transform:scale(1)}50%{opacity:0;transform:scale(1.5)}}.changelog-dot-pulse{background-color:#4ade80;border-radius:50%;animation:1.5s ease-in-out infinite changelog-ping;position:absolute;inset:0}.assets-page{flex-direction:column;gap:1.25rem;height:100%;padding:2rem;display:flex;overflow:hidden}.assets-header{flex-shrink:0;align-items:center;gap:1rem;display:flex}.assets-header-left{flex:1;align-items:baseline;gap:.75rem;display:flex}.assets-header-left h1{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:700}.assets-count{color:var(--text-muted);font-size:.8125rem}.assets-search-wrap{align-items:center;display:flex;position:relative}.assets-search-icon{color:var(--text-muted);pointer-events:none;font-size:.8125rem;position:absolute;left:.75rem}.assets-search{border:1px solid var(--border);background:var(--bg-input);width:220px;height:2rem;color:var(--text-primary);border-radius:8px;outline:none;padding:0 .75rem 0 2.125rem;font-size:.875rem;transition:border-color .15s}.assets-search:focus{border-color:#333}.assets-scroll{flex-direction:column;flex:1;gap:1.5rem;min-height:0;display:flex;overflow-y:auto}.assets-topic-section{flex-direction:column;gap:.625rem;display:flex}.assets-topic-header{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding-bottom:.375rem;display:flex}.assets-topic-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.assets-topic-count{color:var(--text-muted);background:#ffffff0f;border-radius:10px;padding:.125rem .5rem;font-size:.6875rem}.assets-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;display:grid}.asset-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;transition:border-color .15s;overflow:hidden}.asset-card:hover{border-color:#333}.asset-card-thumb{aspect-ratio:16/10;background:#0a0a0a;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.asset-card-img{object-fit:contain;width:100%;height:100%;padding:.5rem}.asset-card-info{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:.5rem;padding:.4rem .5rem .4rem .625rem;display:flex}.asset-card-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.75rem;overflow:hidden}.assets-copy-btn{cursor:pointer;width:22px;height:22px;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:.75rem;transition:background .15s,color .15s;display:flex}.assets-copy-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.assets-empty{height:200px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;font-size:.875rem;display:flex}.assets-empty>i{font-size:2rem}.build-panel-overlay{background:var(--bg-base);border-left:1px solid var(--border);z-index:100;flex-direction:column;width:420px;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-8px 0 32px #0009}.build-panel-container{flex-direction:column;min-width:0;height:100%;display:flex}.build-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;padding:1rem 1.5rem}.build-panel-content{flex:1;min-height:0;padding:1rem 1.5rem;overflow-y:auto}.build-panel-close{cursor:pointer;width:28px;height:28px;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:.875rem;transition:background .15s,color .15s;display:flex}.build-panel-close:hover{background:var(--bg-hover);color:var(--text-primary)}.build-btn-start{color:#f59e0b;cursor:pointer;background:#332815;border:1px solid #4a3520;border-radius:6px;align-items:center;gap:.375rem;height:2.25rem;padding:0 1rem;font-size:.875rem;font-weight:600;transition:filter .15s;display:flex}.build-btn-start:hover{filter:brightness(1.1)}.build-btn-stop{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #ef44444d;border-radius:6px;height:2.25rem;padding:0 1rem;font-size:.875rem;font-weight:600;transition:background .15s}.build-btn-stop:hover{background:#ef44441a}.build-btn-reset{border:1px solid var(--border);height:2.25rem;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;padding:0 1rem;font-size:.875rem;font-weight:600;transition:background .15s}.build-btn-reset:hover{background:#ffffff0f}.build-version-badge{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e40;border-radius:6px;align-items:center;gap:.375rem;height:2.25rem;padding:0 .75rem;font-family:IBM Plex Mono,monospace;font-size:.875rem;font-weight:600;display:flex}.build-ai-output p{margin:.25rem 0}.build-ai-output h2{color:var(--text-primary);margin:.75rem 0 .375rem;font-size:1rem;font-weight:700}.build-ai-output h3{color:var(--text-primary);margin:.5rem 0 .25rem;font-size:.875rem;font-weight:600}.build-ai-output table{border-collapse:collapse;width:100%;margin:.5rem 0;font-size:.8125rem}.build-ai-output th,.build-ai-output td{border-bottom:1px solid var(--border);text-align:left;padding:.375rem .5rem}.build-ai-output th{color:var(--text-secondary);font-size:.75rem;font-weight:600}.build-ai-output code{background:var(--bg-card);color:#aaa;border-radius:3px;padding:.125rem .25rem;font-size:.8125rem}.nav-progress{z-index:9999;pointer-events:none;height:2px;position:fixed;top:0;left:0;right:0;overflow:hidden}.nav-progress-bar{transform-origin:0;background:linear-gradient(90deg,#0000 0%,#0184ff 30%,#4ab3ff 70%,#0000 100%);width:0;height:100%}.nav-progress[data-phase=running] .nav-progress-bar{animation:8s cubic-bezier(.05,.7,.1,1) forwards nav-progress-creep}.nav-progress[data-phase=done] .nav-progress-bar{opacity:0;width:100%;transition:width .15s ease-out,opacity .25s ease-out .1s}@keyframes nav-progress-creep{0%{width:0}20%{width:35%}50%{width:60%}80%{width:80%}to{width:92%}}tr.clickable-row{cursor:pointer;transition:background-color .15s}tr.clickable-row:hover{background-color:#7dd3fc0f}tr.clickable-row:hover td:first-child{color:#7dd3fc}tr.clickable-row:focus-visible{outline-offset:-2px;outline:2px solid #7dd3fc80}
