/* ============================================================
   CASIMIR — 精品藝術品牌官網  共用樣式
   設計 tokens 全集中在 :root，等 Logo / 配色定案改這一區即可整站換膚
   ============================================================ */

:root{
  /* —— 色彩：極簡全白精品（暖白 × 石墨黑，純單色）—— */
  --ink:      #1c1c1c;   /* 石墨黑：主文字 / 髮絲線 */
  --ink-soft: #6e6e6e;   /* 次文字（石墨黑淡化）*/
  --paper:    #fbfbfa;   /* 暖白背景 */
  --paper-2:  #f4f3f1;   /* 區塊底（極淺）*/
  --line:     #e4e3e0;   /* 髮絲線（極淺灰）*/
  --accent:   #1c1c1c;
  --accent-dk:#1c1c1c;
  /* —— 從畫作抽出的胭脂色（editorial 版品牌點綴）—— */
  --blush:      #c7a79c;
  --blush-soft: #ecdfd9;

  /* —— 字體：英文優雅襯線 × 中文極細黑體（字距拉寬）—— */
  --serif:   "Cormorant Garamond", "Noto Serif TC", Georgia, serif;
  --display: "Playfair Display", "Cormorant Garamond", "Noto Serif TC", Georgia, serif; /* 高對比 Didot 感，用於 Logo/大標 */
  --sans:    "Inter", "Noto Sans TC", -apple-system, "Helvetica Neue", sans-serif;

  /* —— 版面（極大留白）—— */
  --maxw: 1240px;
  --gut:  clamp(22px, 6vw, 80px);   /* 左右留白拉大 */
  --nav-h: 84px;
}

/* 中文一律走極細字重＋寬字距，撐出精品呼吸感 */
:lang(zh),.zh{letter-spacing:.14em}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* —— 通用容器 / 留白 —— */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.section{padding:clamp(64px,10vw,128px) 0}
.eyebrow{
  font-size:12px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--blush);font-weight:500;
}
.display{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:.01em}
h1.display{font-size:clamp(40px,7vw,86px)}
h2.display{font-size:clamp(30px,4.5vw,52px)}
.lead{font-size:clamp(16px,1.6vw,19px);color:var(--ink-soft);max-width:60ch}

/* —— 導覽列 —— */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;
  display:flex;align-items:center;
  background:transparent;border-bottom:1px solid transparent;
  transition:background .4s ease,border-color .4s ease,backdrop-filter .4s ease;
}
/* 捲動後才隱約浮現暖白 */
.topbar.scrolled{
  background:rgba(251,251,250,.86);backdrop-filter:saturate(150%) blur(14px);
  border-bottom-color:var(--line);
}
/* 左 Logo / 右選單＋語言（editorial 版） */
.tb-in{width:100%;padding:0 var(--gut);display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center}
.brand img{height:46px;width:auto;display:block}  /* 靜態 fallback：蝌蚪 stacked 標 */

/* —— 動態 Logo：真實向量蝌蚪（向下顯現 → 持續游動 → hover 上浮）—— */
.brand .lk{display:inline-flex;flex-direction:column;align-items:center;gap:5px;line-height:0;
  transition:transform .45s ease}
/* 載入動效：蝌蚪緩慢淡入；CASIMIR 字母由緊密「開展」到正常字距並淡入（時裝屋式） */
/* 蝌蚪：字展開後才登場——壓扁蓄力 → 跳起拉長 → 落地反作用力回彈定位 */
.brand .cmark{height:30px;width:auto;display:block;
  opacity:0;transform-origin:50% 100%;
  animation:cmJump 1.2s ease 2.8s forwards}
@keyframes cmJump{
  0%   {opacity:0; transform:translateY(8%)  scaleX(1.38) scaleY(.58)}
  12%  {opacity:1; transform:translateY(8%)  scaleX(1.38) scaleY(.58)}  /* 壓扁蓄力 */
  42%  {transform:translateY(-55%) scaleX(.82) scaleY(1.20)}            /* 跳起、拉長 */
  64%  {transform:translateY(0)    scaleX(1.16) scaleY(.88)}            /* 落地壓縮（反作用力）*/
  80%  {opacity:1; transform:translateY(-14%) scaleX(.97) scaleY(1.05)}  /* 回彈 */
  92%  {opacity:1; transform:translateY(0)    scaleX(1.03) scaleY(.99)}
  100% {opacity:1; transform:translateY(0)    scale(1)}                  /* 定位、保持顯示 */
}
.brand .cword{display:inline-flex;align-items:flex-end;line-height:0;font-size:12px} /* font-size = 字母高度，動畫量用 em 隨之縮放 */
.brand .cword .gly{height:1em;width:auto;display:block;
  opacity:0;transform:translateX(var(--dx));
  animation:cmGly 2.3s cubic-bezier(.16,1,.3,1) forwards}
@keyframes cmGly{to{opacity:1;transform:translateX(0)}}
/* hover：整體極輕上浮（無放大、無彈跳） */
.brand .lk{transition:transform .5s ease}
.brand:hover .lk{transform:translateY(-1.5px)}

/* —— 開場動畫 Splash：首次造訪全白＋中央 logo，停留後淡出 —— */
.splash{position:fixed;inset:0;z-index:1000;background:var(--paper);
  display:none;align-items:center;justify-content:center}
html.splash-on .splash{display:flex}
html.splash-on,html.splash-on body{overflow:hidden}
.splash.out{opacity:0;transition:opacity 1.6s ease;pointer-events:none}
.splash .lk{flex-direction:column;gap:18px}
.splash .lk .cmark{height:128px}
.splash .lk .cword{font-size:50px}
.tb-right{display:flex;align-items:center;gap:clamp(18px,2.4vw,40px)}
.nav{display:flex;align-items:center;gap:clamp(18px,2.4vw,38px)}
/* 主選單：極小字、寬字距 */
.nav a{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);position:relative;padding:4px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--ink);transition:width .28s}
.nav a:hover::after,.nav a.active::after{width:100%}

/* 語言切換 */
.lang{display:flex;align-items:center;gap:7px;font-size:12.5px;letter-spacing:.06em}
.lang button{background:none;border:none;cursor:pointer;color:var(--ink-soft);font:inherit;padding:2px 3px}
.lang button.on{color:var(--ink);font-weight:600}
.lang .sep{color:var(--line)}

/* 漢堡（行動版） */
.burger{display:none;background:none;border:none;cursor:pointer;width:30px;height:22px;position:relative}
.burger span{position:absolute;left:0;right:0;height:1.5px;background:var(--ink);transition:.3s}
.burger span:nth-child(1){top:0}.burger span:nth-child(2){top:10px}.burger span:nth-child(3){top:20px}

/* —— 按鈕 —— */
.btn{display:inline-flex;align-items:center;gap:10px;font-size:13px;letter-spacing:.14em;
  text-transform:uppercase;padding:15px 34px;border:1px solid var(--ink);color:var(--ink);
  background:none;cursor:pointer;transition:.25s;font-family:inherit}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn.solid{background:var(--ink);color:var(--paper)}
.btn.solid:hover{background:transparent;color:var(--ink)}

/* —— 背景音樂開關（固定右下，低調）—— */
.bgm-btn{position:fixed;right:22px;bottom:20px;z-index:90;width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:50%;background:rgba(251,251,250,.7);
  backdrop-filter:blur(6px);color:var(--ink);cursor:pointer;opacity:.6;transition:opacity .25s,border-color .25s}
.bgm-btn:hover{opacity:1;border-color:var(--ink)}
.bgm-btn svg{width:18px;height:18px;display:block}
.bgm-btn.off{opacity:.4}
@media(max-width:560px){.bgm-btn{right:16px;bottom:16px;width:36px;height:36px}}

/* —— Newsletter 訂閱（頁尾上方，極簡底線式）—— */
.newsletter{border-top:1px solid var(--line);padding:clamp(56px,8vw,92px) 0;text-align:center}
.newsletter .eyebrow{display:block;margin-bottom:18px}
.newsletter .nl-lead{font-family:var(--serif);font-size:clamp(19px,2.2vw,27px);color:var(--ink);
  max-width:28ch;margin:0 auto 30px;line-height:1.4}
.newsletter .nl-lead.zh{font-family:var(--sans);font-weight:300;font-size:clamp(16px,1.9vw,21px);letter-spacing:.12em}
.nl-form{position:relative;display:flex;align-items:center;gap:14px;max-width:400px;margin:0 auto;
  border-bottom:1px solid var(--ink);padding-bottom:9px}
.nl-form input[type=email]{flex:1;border:none;background:none;font-family:inherit;font-size:15px;color:var(--ink);padding:6px 0}
.nl-form input[type=email]:focus{outline:none}
.nl-form button{background:none;border:none;cursor:pointer;font-size:19px;line-height:1;color:var(--ink);transition:transform .25s}
.nl-form button:hover{transform:translateX(5px)}
.nl-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.nl-msg{display:none;font-size:13px;letter-spacing:.04em;margin-top:18px}

/* —— 頁尾：極簡灰線，乾淨低調 —— */
footer{background:var(--paper);border-top:1px solid var(--line);padding:36px 0}
footer .fbot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
footer .fbrand{font-family:var(--display);font-size:15px;letter-spacing:.34em;text-indent:.34em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center}
footer .fbrand img{height:34px;width:auto}
footer .fcopy{font-size:11px;letter-spacing:.12em;color:var(--ink-soft)}
footer .fsoc{display:flex;gap:24px}
footer .fsoc a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);transition:color .2s}
footer .fsoc a:hover{color:var(--ink)}

/* ============================================================
   首頁 Hero —— 不對稱分割：左大襯線排版 / 右作品滿版出血
   ============================================================ */
.hero{min-height:100vh;display:grid;grid-template-columns:46% 54%;align-items:stretch}
.hero-text{display:flex;flex-direction:column;justify-content:center;padding:120px var(--gut) 80px}
.hero-text .eyebrow{margin-bottom:32px}
.hero-text h1{font-family:var(--display);font-weight:400;font-size:clamp(38px,5vw,72px);line-height:1.12;letter-spacing:.01em}
.hero-text h1 em{font-style:italic}
.hero-text .sub{margin-top:28px;max-width:34ch;color:var(--ink-soft);font-size:clamp(15px,1.4vw,17px);line-height:1.9}
.hero-text .sub.zh{font-weight:300}
.hero-text .enter{margin-top:46px;display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:7px;width:fit-content;transition:.3s}
.hero-text .enter:hover{gap:20px;border-bottom-color:var(--blush)}
.hero-img{position:relative;overflow:hidden;background:#fff}
.hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%}

/* —— 宣言帶 The Manifesto —— */
.band{background:var(--blush-soft);text-align:center;padding:clamp(80px,12vw,160px) var(--gut)}
.band p{font-family:var(--serif);font-style:italic;font-size:clamp(24px,3.4vw,44px);line-height:1.45;
  max-width:20ch;margin:0 auto;color:var(--ink)}
.band p.zh{font-style:normal;font-family:var(--sans);font-weight:300;font-size:clamp(19px,2.5vw,30px);max-width:24ch;line-height:1.8}
.band .sign{margin-top:30px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--blush)}

/* —— Selected Works：不對稱兩圖 —— */
.selected{padding:clamp(80px,11vw,150px) var(--gut)}
.selected .head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:clamp(40px,6vw,70px);flex-wrap:wrap;gap:14px}
.selected .head .t{font-family:var(--display);font-size:clamp(26px,3vw,40px)}
.selected .head a{font-size:11px;letter-spacing:.24em;text-transform:uppercase;border-bottom:1px solid var(--line);padding-bottom:6px}
.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,90px);align-items:start}
.duo .two{margin-top:clamp(50px,10vw,150px)}
.duo figure{overflow:hidden;cursor:pointer}
.duo figure img{width:100%;display:block;transition:opacity .5s}
.duo figure:hover img{opacity:.66}
.duo .cap{margin-top:16px}
.duo .cap .t{font-family:var(--serif);font-size:21px}
.duo .cap .m{font-size:12.5px;letter-spacing:.08em;color:var(--ink-soft);margin-top:2px}

@media(max-width:860px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-img{height:78vh;order:-1}
  .hero-img img{position:relative}
  .hero-text{padding:60px var(--gut)}
  .duo{grid-template-columns:1fr;gap:50px}
  .duo .two{margin-top:0}
}

/* —— 雙語切換：中英文都在 HTML，靠 body[data-lang] 顯示其一 —— */
body[data-lang="zh"] .en{display:none}
body[data-lang="en"] .zh{display:none}
/* 行內用法：<span class="zh">中文</span><span class="en">English</span> */

/* ============================================================
   作品集 Works —— 策展分頁 + 不對稱交錯網格 + Lightbox
   ============================================================ */
.page-head{padding-top:calc(var(--nav-h) + clamp(40px,7vw,90px));text-align:center}
.page-head h1.display{margin-bottom:14px}
.page-head h1.display .zh{font-size:clamp(26px,4vw,46px);letter-spacing:.12em}  /* 中文標題縮小、字距收斂 */
.page-head .lead{margin:0 auto}

/* 極簡策展分頁 */
.tabs{display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(20px,4vw,52px);
  margin:clamp(36px,6vw,64px) 0 clamp(48px,7vw,88px)}
.tab{background:none;border:none;cursor:pointer;font-family:inherit;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);
  padding:0 0 8px;position:relative;transition:color .25s}
.tab::after{content:"";position:absolute;left:50%;right:50%;bottom:0;height:1px;background:var(--ink);transition:.3s}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--ink)}
.tab.on::after{left:0;right:0}

/* 交錯瀑布縮圖牆：保留左→右順序，各欄高低錯落形成流動節奏（策展感）*/
.works-grid{display:grid;grid-template-columns:repeat(5,1fr);
  gap:clamp(20px,2.2vw,34px) clamp(16px,1.8vw,28px);align-items:start}
.works-grid[hidden]{display:none}
.works-grid .w-item{transition:transform .3s ease}
/* 5 欄：各欄不規則下沉，避免機械感 */
.works-grid .w-item:nth-child(5n+2){transform:translateY(38px)}
.works-grid .w-item:nth-child(5n+3){transform:translateY(14px)}
.works-grid .w-item:nth-child(5n+4){transform:translateY(52px)}
.works-grid .w-item:nth-child(5n+5){transform:translateY(24px)}
@media(max-width:1024px){
  .works-grid{grid-template-columns:repeat(3,1fr)}
  .works-grid .w-item{transform:none}
  .works-grid .w-item:nth-child(3n+2){transform:translateY(34px)}
  .works-grid .w-item:nth-child(3n+3){transform:translateY(14px)}
}
/* 品牌形象站：去框、去卡紙底，作品開放式浮於白底 */
.w-fig{position:relative;cursor:pointer;overflow:hidden}
.w-fig img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .5s ease}
.w-fig:hover img{opacity:.62}
/* 比例變化，讓版面像時裝雜誌 */
.ar-portrait{aspect-ratio:3/4}
.ar-land{aspect-ratio:4/3}
.ar-tall{aspect-ratio:2/3}
.ar-tarot{aspect-ratio:859/1500}   /* 塔羅卡真實比例，不裁切 */
/* hover 浮現極細作品編號 */
.w-fig .no{position:absolute;left:16px;bottom:14px;font-size:11px;letter-spacing:.24em;
  color:var(--ink);opacity:0;transition:opacity .4s ease;mix-blend-mode:multiply}
.w-fig:hover .no{opacity:.75}
/* 占位狀態才給極淺底，真圖則無框浮現 */
.w-fig .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--paper-2);font-family:var(--display);font-size:46px;letter-spacing:.2em;color:var(--ink-soft);opacity:.55}
.w-meta{margin-top:11px}
.w-meta .t{font-family:var(--serif);font-size:16px;line-height:1.3}
.w-meta .m{font-size:11px;letter-spacing:.08em;color:var(--ink-soft);margin-top:2px}

/* —— Lightbox：全螢幕無邊純白看畫 —— */
.lightbox{position:fixed;inset:0;z-index:200;background:var(--paper);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:86vw;max-height:78vh;object-fit:contain}
.lightbox .lb-ph{width:min(60vw,520px);aspect-ratio:3/4;background:var(--paper-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:64px;color:var(--ink-soft);opacity:.4}
.lightbox .lb-cap{margin-top:26px;text-align:center}
.lightbox .lb-cap .t{font-family:var(--serif);font-size:22px}
.lightbox .lb-cap .m{font-size:12.5px;letter-spacing:.1em;color:var(--ink-soft);margin-top:4px}
.lightbox .lb-close{position:absolute;top:26px;right:32px;background:none;border:none;cursor:pointer;
  font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);transition:color .2s}
.lightbox .lb-close:hover{color:var(--ink)}

@media(max-width:560px){
  .works-grid{grid-template-columns:repeat(2,1fr);gap:18px 14px}
  .works-grid .w-item{transform:none}
  .works-grid .w-item:nth-child(2n){transform:translateY(22px)}
  .w-meta .t{font-size:14px}
}

/* ============================================================
   About & CV
   ============================================================ */
.about-hero{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(40px,6vw,88px);align-items:center;
  padding-top:calc(var(--nav-h) + clamp(40px,7vw,90px))}
.portrait{position:relative;aspect-ratio:4/5;background:var(--paper-2);
  overflow:hidden;filter:grayscale(1) contrast(1.08)}  /* 高對比黑白、無框 */
.portrait img{width:100%;height:100%;object-fit:cover}
.portrait .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:72px;color:var(--ink-soft);opacity:.4}
.about-intro h1.display{margin:14px 0 22px}
.about-intro .lead{font-family:var(--serif);font-size:clamp(20px,2.4vw,28px);color:var(--ink);line-height:1.5}

.bio{max-width:680px;margin:0 auto}
.bio p{margin-bottom:22px;color:var(--ink-soft);font-size:16px;line-height:1.95}
.bio p.zh{font-weight:300}

/* 編年履歷：極細灰線垂直貫穿 */
.cv{max-width:760px;margin:0 auto}
.cv .eyebrow{display:block;text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.cv-list{position:relative;padding-left:30px}
.cv-list::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:1px;background:var(--line)}
.cv-row{position:relative;display:grid;grid-template-columns:84px 1fr;gap:24px;
  padding:18px 0;border-bottom:1px solid var(--line)}
.cv-row:last-child{border-bottom:none}
.cv-row::before{content:"";position:absolute;left:-34px;top:25px;width:7px;height:7px;border-radius:50%;
  background:var(--paper);border:1px solid var(--ink)}
.cv-year{font-family:var(--serif);font-size:18px;color:var(--ink)}
.cv-desc{font-size:14.5px;line-height:1.7;color:var(--ink-soft)}
.cv-desc b{color:var(--ink);font-weight:500}

@media(max-width:760px){
  .about-hero{grid-template-columns:1fr;gap:34px}
  .portrait{max-width:380px;margin:0 auto}
  .cv-row{grid-template-columns:70px 1fr;gap:16px}
}

/* ============================================================
   Inquiries —— 極簡底線表單
   ============================================================ */
.inq{max-width:620px;margin:0 auto}
/* 兩種洽詢類型：底線選取，無粗框 */
.inq-types{display:flex;justify-content:center;gap:clamp(20px,4vw,48px);margin:0 0 clamp(40px,6vw,64px)}
.inq-type{background:none;border:none;cursor:pointer;font-family:inherit;text-align:center;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);
  padding-bottom:9px;border-bottom:1px solid transparent;transition:.25s}
.inq-type:hover{color:var(--ink)}
.inq-type.on{color:var(--ink);border-bottom-color:var(--ink)}

.inq .field{margin-bottom:30px}
.inq label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.inq input,.inq textarea{
  width:100%;border:none;border-bottom:1px solid var(--line);background:transparent;
  font-family:inherit;font-size:16px;color:var(--ink);padding:8px 0;transition:border-color .25s}
.inq input:focus,.inq textarea:focus{outline:none;border-bottom-color:var(--ink)}
.inq textarea{resize:vertical;min-height:120px;line-height:1.7}
.inq .row{display:flex;gap:30px}
.inq .row .field{flex:1}
.inq .actions{margin-top:14px;text-align:center}
.inq-msg{display:none;font-size:14px;letter-spacing:.04em;margin-top:18px;text-align:center}
.cf-turnstile{display:flex;justify-content:center;margin:6px 0 26px}

@media(max-width:560px){.inq .row{flex-direction:column;gap:0}}

/* —— 進場淡入 —— */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* —— 行動版導覽列 —— */
@media(max-width:860px){
  .burger{display:block}
  .nav{position:fixed;inset:var(--nav-h) 0 auto 0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:8px var(--gut) 22px;transform:translateY(-130%);transition:transform .35s;align-items:flex-start}
  .nav.open{transform:none}
  .nav a{width:100%;padding:15px 0;border-bottom:1px solid var(--line);font-size:15px;letter-spacing:.12em}
}
