.logout-btn[data-astro-cid-3ef6ksr2]{font-size:var(--text-xs);color:var(--text-dim);padding:var(--space-2) var(--space-3);border-radius:var(--radius);transition:color var(--transition-fast)}.logout-btn[data-astro-cid-3ef6ksr2]:hover{color:var(--text)}:root{--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--space-10: 64px;--space-12: 96px;--space-16: 128px;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.75rem;--text-4xl: 2.125rem;--text-hero: clamp(2.125rem, 8vw, 3.25rem);--leading-tight: 1.2;--leading-snug: 1.4;--leading-normal: 1.5;--leading-relaxed: 1.7;--leading-loose: 1.75;--reading-width: 36em;--container-wide: 64rem;--bg: #0e0e0e;--surface: #161616;--surface-2: #1f1f1f;--border: #2a2a2a;--border-subtle: #1c1c1c;--text: #f2efe9;--text-mut: #a8a39b;--text-dim: #6b665e;--accent: #ea580c;--accent-hover: #f97316;--danger: #d4543a;--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--font-sans: "Inter", "PingFang TC", "Noto Sans TC", -apple-system, BlinkMacSystemFont, "Microsoft JhengHei", "Heiti TC", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;--transition: .2s cubic-bezier(.16, 1, .3, 1);--transition-fast: .15s cubic-bezier(.16, 1, .3, 1);--shadow-card: 0 1px 2px rgb(0 0 0 / .04), 0 8px 24px rgb(0 0 0 / .06);--lessons-sticky-h: 113px}[data-theme=light]{--bg: #fafaf7;--surface: #ffffff;--surface-2: #f0ede6;--border: #d8d3c8;--border-subtle: #e8e3d8;--text: #1a1a1a;--text-mut: #5a5a5a;--text-dim: #888278;--accent: #c4521a;--accent-hover: #d4622a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-loose);min-height:100dvh;transition:background var(--transition),color var(--transition)}img,picture,video,svg{display:block;max-width:100%;height:auto}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}input,textarea{font:inherit;color:inherit;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:16px}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.container{width:100%;max-width:var(--container-wide);margin:0 auto;padding-inline:var(--space-5)}@media(min-width:768px){.container{padding-inline:var(--space-7)}}.reading{max-width:var(--reading-width);margin:0 auto}h1,h2,h3,h4{color:var(--text);font-weight:700;letter-spacing:-.01em}h1{font-size:var(--text-4xl);line-height:var(--leading-tight)}h2{font-size:var(--text-3xl);line-height:var(--leading-snug)}h3{font-size:var(--text-2xl);line-height:var(--leading-snug)}h4{font-size:var(--text-xl);line-height:var(--leading-normal)}p{margin:0}.eyebrow{font-size:var(--text-xs);font-weight:600;color:var(--text-mut);letter-spacing:.12em;text-transform:uppercase}.lead{font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--text-mut)}.meta{font-size:var(--text-xs);color:var(--text-dim)}.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);height:56px}.header-logo{font-weight:700;font-size:var(--text-base);letter-spacing:-.01em;color:var(--text)}.header-logo:hover{color:var(--accent)}.header-actions{display:flex;align-items:center;gap:var(--space-2)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius);color:var(--text-mut);transition:color var(--transition-fast),background var(--transition-fast)}.theme-toggle:hover{color:var(--text);background:var(--surface)}.theme-toggle .sun-icon{display:none}.theme-toggle .moon-icon,[data-theme=dark] .theme-toggle .sun-icon{display:block}[data-theme=dark] .theme-toggle .moon-icon{display:none}.site-footer{margin-top:var(--space-16);padding:var(--space-8) 0 var(--space-10);border-top:1px solid var(--border-subtle);font-size:var(--text-xs);color:var(--text-dim);text-align:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:48px;padding:0 var(--space-6);border-radius:var(--radius);font-size:var(--text-base);font-weight:600;letter-spacing:.01em;background:var(--accent);color:#fff;transition:background var(--transition-fast),transform var(--transition-fast);text-align:center}.btn:hover{background:var(--accent-hover)}.btn:active{transform:translateY(1px)}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface);border-color:var(--text-dim)}.hero{padding:var(--space-12) 0 var(--space-10)}.hero h1{font-size:var(--text-hero);line-height:var(--leading-tight);margin-bottom:var(--space-5);max-width:18ch}.hero .lead{margin-bottom:var(--space-7);max-width:28ch}.hero-cta{display:flex;gap:var(--space-3);flex-wrap:wrap}.section{padding:var(--space-10) 0;border-top:1px solid var(--border-subtle)}.section h2{margin-bottom:var(--space-5)}.bullet-list{list-style:none;display:grid;gap:var(--space-4)}.bullet-list li{padding-left:var(--space-5);position:relative;color:var(--text)}.bullet-list li:before{content:"·";position:absolute;left:0;color:var(--accent);font-size:1.5em;line-height:1}.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.work-grid figure{aspect-ratio:4 / 5;background:var(--surface);border-radius:var(--radius);overflow:hidden}.work-grid img{width:100%;height:100%;object-fit:cover}.enter-page{min-height:calc(100dvh - 56px);display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.enter-card{width:100%;max-width:360px;text-align:center}.enter-card h1{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.enter-card p.lead{font-size:var(--text-sm);margin-bottom:var(--space-6)}.enter-form{display:grid;gap:var(--space-3)}.enter-input{width:100%;height:56px;padding:0 var(--space-4);font-size:1.125rem;text-align:center}.enter-input.is-error{border-color:var(--danger);animation:shake .3s cubic-bezier(.36,.07,.19,.97)}.enter-error{font-size:var(--text-xs);color:var(--danger);min-height:1em;margin:0}.enter-help{margin-top:var(--space-6);font-size:var(--text-xs);color:var(--text-dim)}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-3px,0,0)}40%,60%{transform:translate3d(3px,0,0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.practice-cta{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text);transition:border-color var(--transition-fast),background var(--transition-fast)}.practice-cta:hover{border-color:var(--accent);background:var(--surface-2)}.practice-cta-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 18%,transparent);border-radius:var(--radius);font-size:var(--text-2xl)}.practice-cta-body h2{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-1);line-height:var(--leading-snug)}.practice-cta-body p{font-size:var(--text-sm);color:var(--text-mut);line-height:var(--leading-relaxed)}.practice-cta-arrow{font-size:var(--text-xl);color:var(--accent);font-weight:600}@media(min-width:768px){.practice-cta{grid-template-columns:80px 1fr auto;padding:var(--space-6)}.practice-cta-icon{width:80px;height:80px;font-size:var(--text-3xl)}.practice-cta-body h2{font-size:var(--text-xl)}}.story{padding-bottom:var(--space-12)}.btn-small{min-height:40px;padding:0 var(--space-4);font-size:var(--text-sm)}.btn-large{min-height:56px;font-size:var(--text-lg);padding:0 var(--space-8)}.story-hero{position:relative;min-height:calc(100dvh - 56px);display:flex;align-items:center;justify-content:center;overflow:hidden;background:#000}.story-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55;z-index:0}.story-hero-content{position:relative;z-index:1;text-align:center;padding:var(--space-7) var(--space-5);max-width:720px;color:#fff}.story-hero-content .eyebrow{display:block;margin-bottom:var(--space-5);color:#fffc}.story-hero-content h1{color:#fff;font-size:var(--text-hero);line-height:var(--leading-tight);margin-bottom:var(--space-6);text-shadow:0 2px 20px rgba(0,0,0,.5)}.story-hero-content .lead{color:#ffffffe6;font-size:var(--text-lg);margin-bottom:var(--space-8)}.scroll-cue{display:inline-flex;flex-direction:column;align-items:center;gap:var(--space-3);color:#ffffffd9;text-decoration:none;font-size:var(--text-sm);transition:color var(--transition-fast)}.scroll-cue:hover{color:#fff}.scroll-cue .cue-arrow{font-size:var(--text-2xl);animation:bob 1.8s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.story-chapter{padding:var(--space-12) 0}.story-chapter.alt{background:var(--surface);border-block:1px solid var(--border-subtle)}.chapter-head{max-width:var(--reading-width);margin:0 auto var(--space-10);padding-inline:var(--space-5);text-align:center}.chapter-num{display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);letter-spacing:.15em;margin-bottom:var(--space-3);padding:var(--space-1) var(--space-3);background:color-mix(in srgb,var(--accent) 12%,transparent);border-radius:999px}.chapter-head h2{font-size:var(--text-4xl);margin-bottom:var(--space-4);line-height:var(--leading-tight)}.chapter-head .lead{font-size:var(--text-base);max-width:36em;margin:0 auto}.story-block{display:grid;grid-template-columns:1fr;gap:var(--space-6);max-width:var(--container-wide);margin:0 auto var(--space-10);padding-inline:var(--space-5);align-items:center}.story-block:last-child{margin-bottom:0}.story-block figure{margin:0;background:#000;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle)}.story-block figure img{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:contain;display:block;background:#000}.story-text h3{font-size:var(--text-2xl);margin-bottom:var(--space-3);line-height:var(--leading-snug)}.story-text p{font-size:var(--text-base);color:var(--text-mut);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.story-text p:last-child{margin-bottom:0}.story-text .btn-small{margin-top:var(--space-2)}@media(min-width:900px){.story-block{grid-template-columns:1.2fr 1fr;gap:var(--space-8)}.story-block.reverse figure{order:2}.story-block.reverse .story-text{order:1}}.composition-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6);max-width:var(--container-wide);margin:0 auto;padding-inline:var(--space-5)}.comp-card{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-fast),transform var(--transition-fast)}.comp-card:hover{border-color:var(--accent)}.comp-num{position:absolute;top:var(--space-4);left:var(--space-4);z-index:2;width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;display:flex;align-items:center;justify-content:center}.comp-card figure{margin:0;background:#000}.comp-card figure img{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:contain;display:block}.comp-body{padding:var(--space-5)}.comp-body h3{font-size:var(--text-xl);margin-bottom:var(--space-3)}.comp-body p{font-size:var(--text-sm);color:var(--text-mut);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}@media(min-width:768px){.composition-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-6)}}@media(min-width:1024px){.composition-grid{grid-template-columns:repeat(3,1fr)}}.practice-callout{display:grid;grid-template-columns:1fr;gap:var(--space-6);max-width:var(--container-wide);margin:0 auto;padding-inline:var(--space-5);background:var(--bg);border:1px solid var(--accent);border-radius:var(--radius-lg);overflow:hidden;padding:var(--space-6);align-items:center}.practice-callout figure{margin:0;background:#000;border-radius:var(--radius);overflow:hidden}.practice-callout figure img{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:contain;display:block}.practice-text h3{font-size:var(--text-2xl);margin-bottom:var(--space-3)}.practice-text p{font-size:var(--text-base);color:var(--text-mut);margin-bottom:var(--space-5);line-height:var(--leading-relaxed)}@media(min-width:900px){.practice-callout{grid-template-columns:1fr 1fr;gap:var(--space-8);padding:var(--space-8)}}.practice-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.story-outro{text-align:center;padding:var(--space-12) var(--space-5);max-width:640px;margin:0 auto}.story-outro img{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:contain;margin-bottom:var(--space-6);background:#000;border-radius:var(--radius-lg)}.story-outro h2{font-size:var(--text-3xl);margin-bottom:var(--space-3)}.story-outro p{color:var(--text-mut);font-size:var(--text-base);line-height:var(--leading-relaxed)}.gallery-page,.admin-page{max-width:var(--container-wide);margin:0 auto;padding:var(--space-7) var(--space-5) var(--space-12)}.gallery-head{text-align:center;margin-bottom:var(--space-8)}.gallery-head .eyebrow{display:block;margin-bottom:var(--space-3)}.gallery-head h1{font-size:var(--text-4xl);margin-bottom:var(--space-3)}.gallery-head .lead{max-width:36em;margin:0 auto;font-size:var(--text-base)}.gallery-upload{display:grid;gap:var(--space-5);max-width:600px;margin:0 auto var(--space-10);padding:var(--space-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.upload-row{display:grid;gap:var(--space-4)}@media(min-width:600px){.upload-row{grid-template-columns:1fr 1fr}}.upload-field{display:flex;flex-direction:column;gap:var(--space-2)}.field-label{font-size:var(--text-sm);color:var(--text-mut);font-weight:500}.field-label em{color:var(--accent);font-style:normal}.upload-field input,.admin-secret-form input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--text-base);color:var(--text);transition:border-color var(--transition-fast)}.upload-field input:focus,.admin-secret-form input:focus{outline:none;border-color:var(--accent)}.upload-drop{position:relative;display:block;min-height:200px;border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;overflow:hidden;transition:border-color var(--transition-fast),background var(--transition-fast)}.upload-drop:hover{border-color:var(--accent);background:var(--surface-2)}.drop-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-7);text-align:center}.drop-icon{font-size:var(--text-3xl)}.drop-text{font-size:var(--text-base);color:var(--text);line-height:var(--leading-snug)}.drop-text small{display:block;margin-top:var(--space-2);font-size:var(--text-xs);color:var(--text-dim)}.drop-preview{position:relative;background:#000}.drop-preview img{width:100%;height:auto;max-height:400px;object-fit:contain;display:block}.drop-reset{position:absolute;top:var(--space-3);right:var(--space-3);width:36px;height:36px;border-radius:50%;background:#000000b3;color:#fff;font-size:var(--text-base);border:1px solid rgba(255,255,255,.3)}.upload-status{font-size:var(--text-sm);color:var(--text-mut);text-align:center;min-height:1.5em;margin:0}.upload-status:not(:empty):before{content:""}#submit-btn:disabled{opacity:.5;cursor:not-allowed}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-5)}.gallery-grid[data-loading=true] .gallery-empty{color:var(--text-dim)}.gallery-empty{grid-column:1 / -1;text-align:center;padding:var(--space-10) 0;color:var(--text-mut)}.gallery-card{margin:0;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:border-color var(--transition-fast),transform var(--transition-fast)}.gallery-card:hover{border-color:var(--border)}.gallery-card img{width:100%;height:auto;aspect-ratio:4 / 5;object-fit:cover;background:#000;display:block}.gallery-card figcaption{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4)}.gallery-card figcaption strong{color:var(--text);font-size:var(--text-base);font-weight:600}.gallery-card figcaption span{color:var(--text-mut);font-size:var(--text-sm);line-height:var(--leading-snug)}.gallery-card figcaption time{color:var(--text-dim);font-size:var(--text-xs);font-family:var(--font-mono);margin-top:var(--space-1)}.admin-secret-form{max-width:400px;margin:0 auto var(--space-8);display:grid;gap:var(--space-4)}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-5)}.admin-card{position:relative;margin:0;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.admin-card img{width:100%;aspect-ratio:4 / 5;object-fit:cover;display:block}.admin-card figcaption{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4)}.admin-card figcaption strong{font-size:var(--text-base);color:var(--text)}.admin-card figcaption span{font-size:var(--text-sm);color:var(--text-mut)}.admin-card figcaption time{font-size:var(--text-xs);color:var(--text-dim);font-family:var(--font-mono)}.btn-danger{margin:0 var(--space-4) var(--space-4);padding:var(--space-2) var(--space-4);background:var(--danger);color:#fff;border-radius:var(--radius);font-size:var(--text-sm);font-weight:500}.btn-danger:hover{opacity:.9}
