*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }
/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,ui-sans-serif,system-ui;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.nav-link{font-size:.875rem;line-height:1.25rem;font-weight:500;--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.nav-link:hover{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:.375rem;padding:.5rem;--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.mobile-menu-btn:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.mobile-menu-btn:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000);--tw-ring-inset:inset;--tw-ring-opacity:1;--tw-ring-color:rgb(200 169 110/var(--tw-ring-opacity,1))}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.top-0{top:0}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-14{margin-top:3.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.aspect-\[4\/3\]{aspect-ratio:4/3}.aspect-video{aspect-ratio:16/9}.h-1\.5{height:.375rem}.h-16{height:4rem}.h-48{height:12rem}.h-6{height:1.5rem}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-48{width:12rem}.w-6{width:1.5rem}.w-full{width:100%}.max-w-3xl{max-width:48rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.flex-shrink-0{flex-shrink:0}.translate-y-2{--tw-translate-y:0.5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-12{gap:3rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.scroll-smooth{scroll-behavior:smooth}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.bg-brand-accent{--tw-bg-opacity:1;background-color:rgb(200 169 110/var(--tw-bg-opacity,1))}.bg-brand-light{--tw-bg-opacity:1;background-color:rgb(245 245 245/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-900{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.bg-gray-900\/0{background-color:rgba(17,24,39,0)}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/90{background-color:hsla(0,0%,100%,.9)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-5{padding:1.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.text-center{text-align:center}.font-sans{font-family:Inter,ui-sans-serif,system-ui}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-brand-accent{--tw-text-opacity:1;color:rgb(200 169 110/var(--tw-text-opacity,1))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ring-4{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-white{--tw-ring-opacity:1;--tw-ring-color:rgb(255 255 255/var(--tw-ring-opacity,1))}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.hover\:border-gray-900:hover{--tw-border-opacity:1;border-color:rgb(17 24 39/var(--tw-border-opacity,1))}.hover\:bg-brand-accent:hover{--tw-bg-opacity:1;background-color:rgb(200 169 110/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-opacity-90:hover{--tw-bg-opacity:0.9}.hover\:text-brand-accent:hover{--tw-text-opacity:1;color:rgb(200 169 110/var(--tw-text-opacity,1))}.hover\:text-gray-900:hover{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.hover\:shadow-md:hover,.hover\:shadow-xl:hover{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-inset:focus{--tw-ring-inset:inset}.group:hover .group-hover\:translate-y-0{--tw-translate-y:0px}.group:hover .group-hover\:scale-105,.group:hover .group-hover\:translate-y-0{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05}.group:hover .group-hover\:scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:bg-gray-900\/40{background-color:rgba(17,24,39,.4)}.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:768px){.md\:flex{display:flex}.md\:hidden{display:none}.md\:h-64{height:16rem}.md\:w-64{width:16rem}.md\:flex-row{flex-direction:row}.md\:justify-start{justify-content:flex-start}.md\:text-left{text-align:left}.md\:text-5xl{font-size:3rem;line-height:1}}@media (min-width:1024px){.lg\:col-span-2{grid-column:span 2/span 2}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}}
/* ═══════════════════════════════════════════════════════════
   Gallery Minimal — Custom classes
   (附加在 Tailwind 編譯輸出後，等候 Marco 提供品牌字體後更新)
   ═══════════════════════════════════════════════════════════ */

/* ─── 自訂游標 ───────────────────────────────────────────── */
/* 預設隱藏；只在有精準指標（滑鼠）時才顯示 */
#custom-cursor { display: none; }

@media (pointer: fine) {
  * { cursor: none !important; }

  #custom-cursor {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 30px;           /* 顯示寬度，可調整 */
    pointer-events: none;  /* 不攔截點擊事件 */
    transform: translate(-50%, 0); /* 圖片頂端對齊游標尖端 */
    opacity: 0;
    transition: opacity 0.2s;
    z-index: 99999;
  }

  #custom-cursor img {
    width: 100%;
    height: auto;
    display: block;
  }
}

/* 等候 Marco 提供字體後，把下面的 font-family 換掉 */
:root {
  --font-display: 'Georgia', 'Noto Serif TC', serif;
  --brand-gold: #C8A96E;
}

/* 導覽連結：小字、灰色、hover 變深 */
.minimal-nav-link {
  font-size: 0.8125rem;
  color: #6b7280;
  transition: color 0.15s ease;
  letter-spacing: 0.01em;
}
.minimal-nav-link:hover {
  color: #111827;
}

/* 畫廊圖片：滿版、cover、hover 微暗 */
.gallery-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
}
.gallery-img.group-hover\:opacity-80:is(:hover, .group:hover .gallery-img) {
  opacity: 0.82;
}

/* 作品 caption：輕量小字，圖片下方 */
.work-caption {
  padding: 0.6rem 0 0;
  line-height: 1.6;
}

/* 分類標籤 / 區塊小標題：最小字、大間距、灰色 */
.section-label {
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #9ca3af;
  line-height: 1.5;
}

/* 內文段落（single-works.php 的 the_content） */
.prose-content p   { margin-bottom: 1.25em; }
.prose-content h2  { font-size: 1rem; font-weight: 600; margin: 1.5em 0 0.5em; }
.prose-content h3  { font-size: 0.9rem; font-weight: 600; margin: 1.25em 0 0.4em; }
.prose-content ul  { list-style: disc; padding-left: 1.25em; margin-bottom: 1em; }
.prose-content ol  { list-style: decimal; padding-left: 1.25em; margin-bottom: 1em; }
.prose-content a   { color: var(--brand-gold); text-decoration: underline; }

/* 補充幾個 Tailwind 沒編譯進來的 utility */
.gap-x-6 { column-gap: 1.5rem; }
.gap-y-12 { row-gap: 3rem; }
.gap-y-1  { row-gap: 0.25rem; }
.gap-x-3  { column-gap: 0.75rem; }
.gap-4    { gap: 1rem; }
.gap-5    { gap: 1.25rem; }
.pt-10    { padding-top: 2.5rem; }
.pt-12    { padding-top: 3rem; }
.pb-5     { padding-bottom: 1.25rem; }
.pb-8     { padding-bottom: 2rem; }
.py-32    { padding-top: 8rem; padding-bottom: 8rem; }
.py-10    { padding-top: 2.5rem; padding-bottom: 2.5rem; }
.mt-16    { margin-top: 4rem; }
.mb-3     { margin-bottom: 0.75rem; }
.mb-6     { margin-bottom: 1.5rem; }
.mb-8     { margin-bottom: 2rem; }
.h-12     { height: 3rem; }
.h-5      { height: 1.25rem; }
.w-5      { width: 1.25rem; }
.border-l { border-left-width: 1px; }
.pl-12    { padding-left: 3rem; }
.pt-8     { padding-top: 2rem; }
.py-6     { padding-top: 1.5rem; padding-bottom: 1.5rem; }
.space-y-6 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * (1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}
.items-end { align-items: flex-end; }
.justify-end { justify-content: flex-end; }
.sm\:items-end { align-items: flex-end; }
.bg-gray-50 { background-color: #f9fafb; }
.mx-1 { margin-left: 0.25rem; margin-right: 0.25rem; }
.py-4  { padding-top: 1rem; padding-bottom: 1rem; }
.gap-9 { gap: 2.25rem; }
.lg\:border-t-0 { border-top-width: 0; }
.lg\:pt-0       { padding-top: 0; }
.lg\:border-l   { border-left-width: 1px; }
.lg\:pl-12      { padding-left: 3rem; }

@media (min-width: 640px) {
  .sm\:items-end    { align-items: flex-end; }
  .sm\:flex-row     { flex-direction: row; }
  .sm\:grid-cols-2  { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
  .lg\:border-t-0 { border-top-width: 0; }
  .lg\:pt-0       { padding-top: 0; }
  .lg\:border-l   { border-left-width: 1px; }
  .lg\:pl-12      { padding-left: 3rem; }
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* ═══════════════════════════════════════════════════════════
   Sidebar Layout — Louis Vincent style complete rebuild
   ═══════════════════════════════════════════════════════════ */

/* ─── Root layout ─────────────────────────────────────────── */
html { height: 100%; }
body { min-height: 100%; background: #A57D59 !important; }

.sidebar {
  position: fixed;
  top: 0; left: 0;
  width: 330px;
  height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 1.75rem 1.75rem;
  background: #A57D59;
  z-index: 20;
  overflow-y: auto;
}

.main-content {
  margin-left: 330px;
  min-height: 100vh;
  background: #A57D59;
  padding-right: 20px;
}

/* ─── Brand Logo ──────────────────────────────────────────── */
.sidebar-brand {
  text-decoration: none;
  display: flex;
  justify-content: center;
  flex-shrink: 0;
}

.sidebar-logo {
  width: 100%;
  max-width: 240px;
  height: auto;
  display: block;
}

/* 桌面/iPad：顯示原 Logo，隱藏手機 Logo */
.sidebar-logo-mobile { display: none; }

/* 手機版：隱藏原 Logo，顯示手機 Logo */
@media (max-width: 640px) {
  .sidebar-logo-desktop { display: none; }
  .sidebar-logo-mobile  { display: block; max-width: 50px; }
}

/* ─── Nav block (vertically centred) ─────────────────────── */
.sidebar-nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0;
}

.sidebar-nav a {
  display: block;
  font-size: 1rem;
  font-weight: 700;
  color: #67482F;
  text-decoration: none;
  line-height: 2.1;
  transition: color 0.15s;
}

.sidebar-nav a:hover { color: #3d2a1a; }

.sidebar-nav-section {
  margin-top: 1.1rem;
}

.sidebar-nav-label {
  display: block;
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: none;
  color: #9ca3af;
  line-height: 2;
}

/* 年份子項目：原本的大小與格式，不繼承粗體 */
.sidebar-nav a.sidebar-nav-year {
  padding-left: 0;
  font-size: 0.9rem;
  font-weight: 400;
  line-height: 1.5;
}

/* ─── Sidebar footer (bottom) ────────────────────────────── */
.sidebar-footer {
  flex-shrink: 0;
  font-size: 0.85rem;
  color: #ffffff;
  line-height: 1.75;
}

.sidebar-footer a {
  display: block;
  color: #ffffff;
  text-decoration: none;
  transition: color 0.15s;
  line-height: 1.5;
}

.sidebar-footer a:hover { color: rgba(255,255,255,0.7); }

.sidebar-footer .sf-copy { margin-top: 0.75rem; }

/* ─── Works grid ─────────────────────────────────────────── */
.works-grid-main {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  padding-top: 20px;
}

.work-cell {}

.work-cell-img {
  display: block;
  aspect-ratio: 4/5;
  background: #efefed;   /* 淺灰背景，陶藝作品攝影的底色 */
  overflow: hidden;
  text-decoration: none;
  position: relative;
}

/* contain：讓整件作品完整顯示在灰色背景上，不裁切 */
.work-cell-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  padding: 6%;               /* 四周留白，讓作品不貼邊 */
  box-sizing: border-box;
  transition: opacity 0.3s ease;
}

.work-cell-img:hover img { opacity: 0.82; }

.work-cell-no-img {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6875rem;
  color: #9ca3af;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* caption：四行相同字級、相同灰色，與 Louis Vincent 一致 */
.work-cell-caption {
  padding: 0.55rem 0.4rem 1.6rem;
  font-size: 0.8125rem;
  color: #5a5a5a;
  line-height: 1.7;
}

/* 標題行：顏色略深一點，可點擊 */
.work-cell-caption .wc-title {
  color: #67482F;
  text-decoration: none;
  display: block;
  font-weight: 700;
}
.work-cell-caption .wc-title:hover { color: #5a2d16; }

.work-cell-caption .wc-meta { color: #5a5a5a; }
.work-cell-caption .wc-subs { display: flex; flex-direction: column; line-height: 1.2; }
.work-cell-caption .wc-sub  { color: #C9BC9C; }

/* ─── Single work detail ─────────────────────────────────── */
.single-hero-img {
  width: 100%;
  background: #f0efed;
  line-height: 0;
}

.single-hero-img img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 85vh;
  object-fit: cover;
}

/* ─── Single work page ───────────────────────────────────── */

.single-back-bar {
  padding: 1.5rem 0 0.5rem;
}

.single-wrap {
  padding: 0 0 1.5rem;
  max-width: 860px;
}

/* 桌面：橫向滾動 */
.single-images {
  display: flex;
  flex-direction: row;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  gap: 6px;
  margin-bottom: 0;
  height: 85vh;
  scrollbar-width: none;
  -ms-overflow-style: none;
  cursor: grab;
  user-select: none;
}
.single-images:active { cursor: grabbing; }
.single-images::-webkit-scrollbar { display: none; }

.single-img-item {
  flex-shrink: 0;
  scroll-snap-align: start;
  height: 100%;
}

.single-img-item img {
  height: 100%;
  width: auto;
  display: block;
  pointer-events: none;
}

.single-detail-row {
  display: flex;
  gap: 1.5rem;
  font-size: 0.8125rem;
  color: #67482F;
  line-height: 1.12;
}

.single-detail-label {
  width: 90px;
  flex-shrink: 0;
  color: #67482F;
}

.single-enquiry {
  margin-top: 2rem;
  font-size: 0.75rem;
}

.single-enquiry a {
  color: #67482F;
  text-decoration: none;
}

.single-enquiry a:hover { text-decoration: underline; }

.single-meta-wrap {
  padding: 0.55rem 0 1rem 0.4rem;
  max-width: 520px;
}

.single-back {
  font-size: 0.85rem;
  color: #67482F;
  text-decoration: none;
  display: block;
  margin-bottom: 0.25rem;
  transition: opacity 0.15s;
}
.single-back:hover { opacity: 0.6; }

.single-title {
  font-size: 0.8125rem;
  color: #67482F;
  font-weight: 700;
  margin: 0 0 0.1rem;
}

.single-detail {
  font-size: 0.6875rem;
  color: #67482F;
  line-height: 1.75;
}

.single-content {
  margin-top: 1.5rem;
  font-size: 0.8125rem;
  color: #67482F;
  line-height: 1.75;
}
.single-content p { margin-bottom: 0.875em; }

.single-work-nav {
  padding: 1rem 0;
  border-top: 1px solid #67482F;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  font-size: 0.85rem;
  color: #67482F;
}

.single-work-nav > *:last-child {
  text-align: right;
  justify-self: end;
}

.single-work-nav a {
  color: #67482F;
  text-decoration: none;
  font-size: 0.85rem;
  transition: color 0.15s;
}

.single-work-nav a:hover { opacity: 0.6; }

/* ─── Photo credit floating label ────────────────────────── */
#photo-credit {
  position: fixed;
  pointer-events: none;
  display: none;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: #67482F;
  white-space: nowrap;
  z-index: 9999;
  transform: translate(18px, calc(-50% + 10px));
}

/* ─── About / generic page ───────────────────────────────── */
.about-wrap {
  padding: 3rem 3rem 4rem;
  max-width: 660px;
}

.about-wrap h1 {
  font-size: 0.6875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9ca3af;
  font-weight: 400;
  margin-bottom: 2.5rem;
}

/* ─── Information page ───────────────────────────────────── */
.info-text-area {
  padding: 0;
}

/* 每個區塊：標題 + 內文上下排列，區塊之間有間距 */
.info-section {
  max-width: 520px;
  padding: 0 0 2.5rem;
}

/* Slogan 區塊：撐滿 info-text-area 全寬（與下方兩欄左右外緣對齊） */
.info-text-area > .info-section {
  max-width: none;
}

/* Brand Philosophy（左）+ Founder（右）並排兩欄，標題行等高讓內文上緣對齊 */
.info-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto 1fr;
  gap: 0 3rem;
  max-width: 100%;
}

.info-columns .info-section {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  max-width: none;
}

.info-section-title {
  font-size: 24px;
  font-weight: 700;
  color: #67482F;
  margin: 0 0 0.6rem;
  line-height: 1.3;
}

.info-section-text {
  font-size: 0.8125rem;
  font-weight: 400;
  color: #67482F;
  line-height: 1.9;
}

/* Slogan 內文：大字斜體 */
.info-slogan-text {
  font-size: 60px;
  font-style: italic;
  line-height: 1.2;
  transition: color 0.2s ease;
}
.info-slogan-text:hover { color: #814324; }

/* 手機 */
@media (max-width: 640px) {
  .info-section {
    padding: 0 1.25rem 2rem 0.4rem;
  }
  .info-columns {
    grid-template-columns: 1fr;
  }
  .info-columns .info-section {
    display: block;
    grid-row: auto;
  }
}

.about-body {
  font-size: 0.8125rem;
  color: #374151;
  line-height: 1.85;
}

.about-body p { margin-bottom: 1em; }
.about-body h2 { font-size: 0.75rem; font-weight: 600; margin: 1.5em 0 0.5em; color: #111827; }
.about-body a { color: #C8A96E; }

.about-meta {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid #f3f4f6;
}

.about-meta h3 {
  font-size: 0.6875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9ca3af;
  font-weight: 400;
  margin-bottom: 1rem;
}

/* ─── iPad / Tablet（641px–1024px）─────────────────────────── */
@media (max-width: 1024px) and (min-width: 641px) {
  .works-grid-main { grid-template-columns: repeat(2, 1fr); }
  .info-slogan-text { font-size: 40px; }
  .sidebar { width: 260px; padding: 1.5rem; }
  .main-content { margin-left: 260px; }
}

/* Mobile 導航連結：桌面隱藏 */
.sidebar-mobile-links { display: none; }

/* Arc 下拉選單：桌面隱藏 */
.mob-arc-toggle  { display: none; }
.mob-arc-dropdown { display: none; }

/* ─── Mobile ─────────────────────────────────────────────── */
@media (max-width: 640px) {
  .sidebar {
    position: fixed;
    top: 0; left: 0; right: 0;
    width: 100%;
    height: auto;
    flex-direction: row;
    align-items: center;
    padding: 0.75rem 1.25rem 0.75rem 10px;
    border-bottom: 1px solid #f3f4f6;
  }

  .sidebar-nav,
  .sidebar-footer,
  .sidebar-mobile-btn { display: none; }

  /* 手機版直接顯示 Information / Archive 連結 */
  .sidebar-mobile-links {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    margin-left: auto;
  }
  .sidebar-mobile-links a {
    font-size: 15px;
    font-weight: 700;
    color: #67482F;
    text-decoration: none;
    white-space: nowrap;
  }
  .sidebar-mobile-links a:hover { opacity: 0.65; }

  /* Arc 切換按鈕 */
  .mob-arc-toggle {
    display: inline;
    font-size: 15px;
    font-weight: 700;
    color: #67482F;
    cursor: pointer;
    white-space: nowrap;
    user-select: none;
  }
  .mob-arc-toggle:hover { opacity: 0.65; }

  /* Arc 下拉選單（fixed，移出 aside 避免被 overflow 裁切；top/left 由 JS 設定） */
  .mob-arc-dropdown {
    position: fixed;
    background: #A57D59;
    min-width: 60px;
    padding: 0.1rem 0;
    z-index: 100;
  }
  .mob-arc-dropdown a {
    display: block;
    font-size: 12px;
    font-weight: 300;
    color: #67482F;
    text-decoration: none;
    padding: 0.15rem 0.5rem 0.15rem 4px;
  }
  .mob-arc-dropdown a:hover { opacity: 0.7; }

  .sidebar-mobile-menu {
    display: none;
    position: fixed;
    top: 44px; left: 0; right: 0;
    background: #fff;
    border-bottom: 1px solid #f3f4f6;
    padding: 1.25rem 1.5rem;
    z-index: 19;
  }

  .sidebar-mobile-menu.is-open { display: block; }

  .sidebar-mobile-menu a {
    display: block;
    font-size: 0.875rem;
    color: #374151;
    text-decoration: none;
    padding: 0.5rem 0;
    border-bottom: 1px solid #f9fafb;
  }

  .main-content {
    margin-left: 0;
    margin-top: 44px;
    padding-left: 10px;
    padding-right: 10px;
  }

  .works-grid-main { grid-template-columns: 1fr; }
  .info-slogan-text { font-size: 28px; line-height: 1.4; }

  .about-wrap { padding: 1.5rem 1.25rem 3rem; }
  .single-meta-wrap { padding: 0.55rem 1.25rem 3rem 0; }

  /* 手機：圖片改回上下堆疊 */
  .single-images {
    flex-direction: column;
    overflow-x: unset;
    scroll-snap-type: unset;
    height: auto;
    cursor: default;
  }

  .single-img-item {
    flex-shrink: unset;
    height: auto;
    width: 100%;
  }

  .single-img-item img {
    height: auto;
    width: 100%;
    pointer-events: auto;
  }

  .single-back-bar {
    padding: 1.25rem 1.25rem 1rem 0.4rem;
  }

  .single-wrap {
    padding: 0 1.25rem 3rem 0.4rem;
  }
}

/* 漢堡按鈕全站隱藏（手機改用直接連結） */
.sidebar-mobile-btn { display: none; }

/* 手機版頁底版權 */
.mob-page-footer { display: none; }

@media (max-width: 640px) {
  .mob-page-footer {
    display: block;
    text-align: center;
    font-size: 0.75rem;   /* 12px */
    font-weight: 300;
    color: #ffffff;
    background: #A57D59;
    padding: 1.25rem 1rem;
    margin-top: 0;
    position: relative;
  }

  /* 版權上方橫線：absolute 定位，left/right 直接對應圖片兩側外緣 */
  .mob-page-footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 10px;   /* 對齊圖片左側外緣 */
    right: 10px;  /* 對齊圖片右側外緣（main-content padding-right:10px） */
    height: 0.5px;
    background: #67482F;
  }
}
