:root{--bg:#10080f;--surface:#1a1017;--surface2:#24141d;--text:#fff8f2;--muted:#cbb8b2;--gold:#dbb56a;--wine:#751f36;--rose:#b94a66;--line:rgba(255,255,255,.11);--ok:#29b36b;--radius:18px;--max:1160px;--shadow:0 18px 54px rgba(0,0,0,.38)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:"Noto Sans TC","Microsoft JhengHei","PingFang TC",Arial,sans-serif;color:var(--text);background:radial-gradient(900px 600px at 80% -10%,rgba(219,181,106,.14),transparent 55%),radial-gradient(800px 600px at 10% 0,rgba(185,74,102,.24),transparent 55%),var(--bg);line-height:1.65}a{text-decoration:none;color:inherit}.container{max-width:var(--max);margin:auto;padding:0 20px}
.nav{position:sticky;top:0;z-index:30;background:rgba(16,8,15,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}.navin{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:18px}.brand{display:flex;align-items:center;gap:14px;font-weight:900;min-width:0}.brand-logo{display:block;width:142px;height:auto;max-height:60px;object-fit:contain;object-position:left center;filter:drop-shadow(0 9px 20px rgba(219,181,106,.14))}.brand-title{display:flex;flex-direction:column;line-height:1.1;white-space:nowrap}.brand-title b{font-size:17px;letter-spacing:.08em}.brand small{display:block;color:var(--muted);font-weight:500;font-size:11px;letter-spacing:.12em}.menu{display:flex;align-items:center;gap:17px;flex-wrap:wrap}.menu a{font-size:14px;color:var(--muted);font-weight:700}.menu a:hover{color:var(--text)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:12px;padding:11px 16px;border:1px solid var(--line);background:rgba(255,255,255,.055);font-weight:800;color:var(--text);cursor:pointer}.btn.primary{border:0;background:linear-gradient(100deg,var(--wine),var(--rose));box-shadow:0 13px 35px rgba(117,31,54,.4)}.btn.gold{background:var(--gold);color:#211116;border:0}.btn.small{padding:7px 11px;font-size:13px}.btn:hover{transform:translateY(-1px)}
.setup{padding:9px 20px;background:#2b1720;color:#f6dfb3;text-align:center;font-size:13px}.setup a{text-decoration:underline;font-weight:bold}.hero{padding:42px 0 38px}.hero-logo{display:block;width:min(280px,70vw);height:auto;margin:0 0 16px;filter:drop-shadow(0 14px 28px rgba(219,181,106,.16))}.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:24px;align-items:stretch}.eyebrow{display:inline-flex;padding:6px 12px;border-radius:999px;border:1px solid rgba(219,181,106,.4);color:#efd28f;font-size:13px;font-weight:800;margin-bottom:15px}.hero h1{margin:0 0 14px;font-size:48px;line-height:1.16;letter-spacing:.04em}.hero h1 span{color:var(--gold)}.hero p{color:var(--muted);font-size:16px;margin:0 0 22px}.actions{display:flex;gap:10px;flex-wrap:wrap}.hero-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:26px;min-height:400px;background:linear-gradient(130deg,rgba(117,31,54,.35),rgba(0,0,0,.35)),linear-gradient(35deg,#381724,#140b11)}.hero-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 15%,rgba(219,181,106,.32),transparent 28%),linear-gradient(125deg,transparent 40%,rgba(185,74,102,.24),transparent 70%)}.stage{position:absolute;bottom:0;left:0;right:0;padding:22px;background:linear-gradient(transparent,rgba(9,5,9,.92));z-index:2}.stage h3{margin:0 0 5px;font-size:22px}.stage p{margin:0;color:var(--muted)}
.section{padding:38px 0}.head{display:flex;justify-content:space-between;align-items:end;gap:12px;margin-bottom:18px}.head h2{margin:0;font-size:30px}.head p{margin:0;color:var(--muted)}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.card{border-radius:var(--radius);background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.035));border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}.card-body{padding:18px}.cover{height:188px;background:linear-gradient(135deg,#4c1b31,#1c1018);display:grid;place-items:center;color:rgba(255,255,255,.42);font-weight:800}.cover img{height:100%;width:100%;object-fit:cover}.tag{display:inline-flex;padding:5px 10px;border-radius:999px;background:rgba(219,181,106,.15);border:1px solid rgba(219,181,106,.35);color:#eed18f;font-size:12px;font-weight:800}.card h3{margin:12px 0 7px;font-size:19px}.muted{color:var(--muted)}.meta{color:var(--muted);font-size:14px;display:flex;gap:10px;flex-wrap:wrap}.price{color:var(--gold);font-size:24px;font-weight:900}.artist{text-align:center;padding:20px}.artist .photo{margin:auto;width:94px;height:94px;border-radius:50%;background:linear-gradient(135deg,var(--wine),var(--gold));overflow:hidden}.artist .photo img{width:100%;height:100%;object-fit:cover}.artist h3{margin-bottom:0}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.full{grid-column:1/-1}label{display:block;color:var(--muted);font-size:13px;margin-bottom:6px;font-weight:700}input,textarea,select{width:100%;background:#150d13;color:var(--text);border:1px solid rgba(255,255,255,.15);padding:12px;border-radius:11px}textarea{min-height:105px;resize:vertical}.alert{padding:12px 14px;border-radius:12px;margin:14px 0}.alert.success{background:rgba(41,179,107,.12);border:1px solid rgba(41,179,107,.3)}.alert.error{background:rgba(185,74,102,.16);border:1px solid rgba(185,74,102,.35)}
.event-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:20px}.ticket{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}.ticket:last-child{border:0}.list{margin:0;padding-left:18px;color:var(--muted)}.member-wrap{max-width:880px;margin:36px auto}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:12px;border-bottom:1px solid var(--line)}th{color:var(--muted);font-size:12px}.status{font-size:12px;padding:4px 8px;border-radius:999px;background:rgba(219,181,106,.12);color:#efd28f}.footer{margin-top:38px;padding:28px 0;border-top:1px solid var(--line);color:var(--muted);font-size:13px}.split{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
@media(max-width:900px){.navin{min-height:70px}.brand-logo{width:112px;max-height:46px}.brand-title{display:none}.hero-grid,.event-layout,.grid3,.grid2,.form-grid{grid-template-columns:1fr}.hero h1{font-size:36px}.menu a:not(.btn){display:none}.hero-card{min-height:320px}}
.points-card{display:flex;flex-direction:column;gap:4px;padding:14px 16px;margin:16px 0;border-radius:14px;border:1px solid rgba(219,181,106,.35);background:rgba(219,181,106,.08);color:var(--text)}.points-card b{color:var(--gold);font-size:18px}.points-card span{font-size:13px;color:var(--muted)}.summary{padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.035);display:flex;flex-direction:column;gap:3px}.summary b{color:var(--gold)}.target{display:inline-flex;margin-top:4px;color:#efd28f;font-size:13px}.point-used{font-size:12px;color:#efd28f}.member-cards{display:grid;grid-template-columns:1.1fr .9fr;gap:16px;margin:18px 0}.points-balance{border-radius:var(--radius);padding:22px;background:linear-gradient(120deg,rgba(117,31,54,.78),rgba(219,181,106,.2));border:1px solid rgba(219,181,106,.35);display:flex;flex-direction:column;gap:4px}.points-balance span{color:#f1ded0;font-size:14px}.points-balance b{font-size:36px;color:#efd28f}.points-balance small{color:var(--muted)}.panel.mini{margin:0}.panel.mini h3{margin:0 0 8px}.point-plus{color:#59d692;font-weight:800}.point-minus{color:#ff9cab;font-weight:800}
@media(max-width:900px){.member-cards{grid-template-columns:1fr}}

/* V2.4 Brand story */
.story{padding-top:10px}
.story-panel{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:28px;padding:30px;background:linear-gradient(135deg,rgba(66,22,37,.72),rgba(17,9,15,.98));box-shadow:0 20px 55px rgba(0,0,0,.2)}
.story-panel:after{content:"";position:absolute;right:-140px;top:-180px;width:420px;height:420px;background:radial-gradient(circle,rgba(219,181,106,.15),transparent 64%);pointer-events:none}
.story-head{display:flex;align-items:center;gap:16px;margin-bottom:24px}.story-head .eyebrow{margin:0}.story-head h2{margin:0;font-size:30px}
.story-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:24px;position:relative;z-index:1}
.story-origin{display:flex;gap:18px;padding:22px;border-radius:20px;background:rgba(255,255,255,.035);border:1px solid rgba(219,181,106,.12)}
.story-icon{font-size:32px;line-height:1}
.story-origin h3,.vision h3{margin:0 0 12px;font-size:22px;color:var(--gold)}
.story-origin p{margin:0 0 13px;color:var(--muted);line-height:1.85}.story-origin p:last-child{margin-bottom:0}
.vision{padding:22px;border-radius:20px;background:rgba(7,4,8,.28);border:1px solid rgba(255,255,255,.08)}
.vision-list{display:grid;gap:14px}.vision-item{display:flex;gap:13px;padding:13px;border-radius:15px;background:rgba(255,255,255,.035)}
.vision-item>span{font-size:23px;line-height:1.3}.vision-item h4{margin:0 0 5px;font-size:16px;color:var(--text)}.vision-item p{margin:0;color:var(--muted);font-size:14px;line-height:1.6}
@media(max-width:900px){.story-panel{padding:20px}.story-head{display:block}.story-head .eyebrow{margin-bottom:12px}.story-grid{grid-template-columns:1fr}.story-origin{display:block}.story-icon{margin-bottom:10px}}


/* V2.5 首頁順序：品牌故事置頂，主視覺接續顯示 */
.story-first{padding-top:42px;padding-bottom:18px}
.hero-after-story{padding-top:14px}
@media(max-width:900px){.story-first{padding-top:26px;padding-bottom:12px}.hero-after-story{padding-top:10px}}


/* V2.6 品牌故事版面：依指定示意圖重製 */
.brand-story-showcase{
  background:#101927;
  color:#efeae8;
  padding:38px 0 46px;
  border-bottom:1px solid rgba(255,255,255,.035);
}
.story-showcase-container{
  width:min(1680px,calc(100% - 72px));
  margin:0 auto;
}
.story-showcase-header{
  text-align:center;
  margin:0 0 68px;
}
.story-showcase-header h2{
  margin:0;
  color:#ff913d;
  font-size:clamp(38px,3.1vw,60px);
  line-height:1.16;
  font-weight:900;
  letter-spacing:.08em;
}
.story-title-line{
  display:block;
  width:132px;
  height:7px;
  margin:25px auto 0;
  border-radius:99px;
  background:linear-gradient(90deg,#ff8f27 0%,#ff463e 100%);
}
.story-showcase-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(520px,.97fr);
  gap:64px;
  align-items:center;
}
.rebirth-story{
  padding:12px 0 18px 0;
}
.rebirth-fire{
  font-size:72px;
  line-height:1;
  text-align:center;
  margin:0 0 28px;
  filter:drop-shadow(0 5px 12px rgba(255,120,35,.22));
}
.rebirth-story h3{
  margin:0 0 42px;
  text-align:center;
  color:#ff963f;
  font-size:clamp(27px,1.9vw,34px);
  font-weight:850;
  letter-spacing:.04em;
}
.rebirth-story p{
  margin:0 0 28px;
  color:#d2d0d3;
  font-size:clamp(18px,1.22vw,22px);
  line-height:2.08;
  font-weight:500;
}
.rebirth-story p:last-child{margin-bottom:0}
.rebirth-story strong{color:#ff963f;font-weight:900}
.vision-card{
  padding:46px 48px 38px;
  min-height:490px;
  border:1px solid rgba(221,104,35,.62);
  border-radius:23px;
  background:linear-gradient(135deg,#4b312b 0%,#422528 100%);
  box-shadow:0 22px 60px rgba(0,0,0,.14);
}
.vision-card>h3{
  margin:0 0 34px;
  color:#ff953e;
  font-size:clamp(28px,2vw,35px);
  line-height:1.25;
  font-weight:900;
}
.vision-card-list{
  display:grid;
  gap:30px;
}
.vision-card-item{
  display:grid;
  grid-template-columns:44px 1fr;
  gap:14px;
  align-items:start;
}
.vision-emoji{
  font-size:25px;
  line-height:1.45;
  display:block;
}
.vision-card-item h4{
  margin:0 0 10px;
  color:#fff8f1;
  font-size:clamp(18px,1.23vw,22px);
  font-weight:800;
  line-height:1.35;
}
.vision-card-item p{
  margin:0;
  color:#d4c7c5;
  font-size:clamp(16px,1.12vw,20px);
  font-weight:500;
  line-height:1.8;
}
.brand-story-showcase + .hero.hero-after-story{
  padding-top:40px;
}
@media(max-width:1180px){
  .story-showcase-container{width:min(100% - 42px,1000px)}
  .story-showcase-grid{grid-template-columns:1fr;gap:38px}
  .rebirth-story{max-width:820px;margin:0 auto}
  .vision-card{max-width:820px;margin:0 auto;min-height:0;width:100%}
  .story-showcase-header{margin-bottom:46px}
}
@media(max-width:640px){
  .brand-story-showcase{padding:28px 0 32px}
  .story-showcase-container{width:calc(100% - 30px)}
  .story-showcase-header{margin-bottom:36px}
  .story-showcase-header h2{font-size:34px}
  .story-title-line{width:92px;height:5px;margin-top:17px}
  .rebirth-fire{font-size:54px;margin-bottom:18px}
  .rebirth-story h3{font-size:24px;margin-bottom:24px}
  .rebirth-story p{font-size:16px;line-height:1.85;margin-bottom:20px}
  .vision-card{padding:26px 19px 24px;border-radius:18px}
  .vision-card>h3{font-size:25px;margin-bottom:24px}
  .vision-card-list{gap:22px}
  .vision-card-item{grid-template-columns:35px 1fr;gap:10px}
  .vision-card-item h4{font-size:17px}
  .vision-card-item p{font-size:15px;line-height:1.6}
}


/* V2.7 首頁主視覺：左側不顯示 Logo，右側可上傳介紹照片 */
.hero-copy{display:flex;flex-direction:column;justify-content:center}
.hero-card.has-intro-image{background:#130b10}
.hero-card.has-intro-image:before{
  z-index:1;
  background:linear-gradient(180deg,rgba(7,4,8,.03),rgba(7,4,8,.15));
  pointer-events:none;
}
.hero-intro-image{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
  z-index:0;
}


/* V2.8 場次多照片／影片展示 */
.event-media-detail{padding-top:6px}
.event-photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:34px}
.event-photo-card{margin:0;overflow:hidden;border-radius:17px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}
.event-photo-card img{display:block;width:100%;height:220px;object-fit:cover;transition:transform .25s ease}
.event-photo-card a:hover img{transform:scale(1.035)}
.event-photo-card figcaption{padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.event-photo-card figcaption b{font-size:15px}
.event-photo-card figcaption span{color:var(--muted);font-size:13px}
.event-video-heading{margin-top:10px}
.event-video-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.event-video-card{border:1px solid var(--line);border-radius:18px;padding:16px;background:var(--surface);box-shadow:var(--shadow)}
.event-video-card h3{margin:0 0 12px;font-size:19px}
.event-video-frame{aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#070407}
.event-video-frame iframe,.event-video-frame video{width:100%;height:100%;display:block;border:0;object-fit:cover}
.event-video-card p{margin:10px 0 0}
@media(max-width:860px){.event-photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.event-video-grid{grid-template-columns:1fr}}
@media(max-width:560px){.event-photo-grid{grid-template-columns:1fr}.event-photo-card img{height:235px}}

/* 鳳凰群星 30 位歌手陣容 */
.singer-hero{padding:62px 0 38px;background:radial-gradient(700px 360px at 80% 10%,rgba(219,181,106,.2),transparent 60%),linear-gradient(180deg,rgba(117,31,54,.18),transparent)}
.singer-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}.singer-hero h1{font-size:52px;margin:0 0 14px;color:var(--gold)}.singer-hero p{font-size:18px;color:var(--muted)}.lineup-stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.lineup-stats span{padding:11px 15px;border:1px solid rgba(219,181,106,.35);border-radius:14px;background:rgba(255,255,255,.045);color:var(--muted)}.lineup-stats b{font-size:25px;color:var(--gold)}.singer-hero-note{padding:28px;border:1px solid rgba(219,181,106,.3);border-radius:24px;background:linear-gradient(135deg,rgba(219,181,106,.12),rgba(117,31,54,.18));box-shadow:var(--shadow)}.singer-hero-note b{font-size:25px;color:#f1d593}
.singer-filter{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:24px;padding:14px;border-radius:18px;background:rgba(255,255,255,.045);border:1px solid var(--line)}.filter-tabs{display:flex;gap:8px;flex-wrap:wrap}.filter-tabs a{padding:9px 14px;border-radius:10px;color:var(--muted);font-weight:800}.filter-tabs a.active,.filter-tabs a:hover{background:var(--gold);color:#211116}.singer-search{display:flex;gap:8px}.singer-search input{min-width:250px}
.singer-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.singer-card{overflow:hidden;border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025));box-shadow:var(--shadow);transition:.25s}.singer-card:hover{transform:translateY(-5px);border-color:rgba(219,181,106,.5)}.singer-photo{display:grid;place-items:center;position:relative;aspect-ratio:4/5;overflow:hidden;background:linear-gradient(145deg,#65304b,#1b1118)}.singer-photo.male{background:linear-gradient(145deg,#234a6b,#101b29)}.singer-photo img{width:100%;height:100%;object-fit:cover}.singer-photo>span{font-size:78px;font-weight:900;color:rgba(255,255,255,.84)}.singer-photo em{position:absolute;top:12px;right:12px;padding:5px 9px;border-radius:999px;background:rgba(16,8,15,.78);border:1px solid rgba(219,181,106,.5);color:#f1d593;font-size:11px;font-style:normal}.singer-card-body{padding:17px}.singer-card-top{display:flex;justify-content:space-between;gap:8px}.singer-card-top small{color:var(--muted);font-size:11px}.gender-tag{display:inline-flex;padding:5px 9px;border-radius:999px;background:rgba(185,74,102,.18);color:#f1a8ba;font-size:11px;font-weight:900}.gender-tag.male{background:rgba(58,120,180,.2);color:#9ed0ff}.singer-card h3{font-size:22px;margin:10px 0 0}.singer-card strong{display:block;color:var(--gold);font-size:13px;margin:3px 0 9px}.singer-card p{color:var(--muted);font-size:13px;min-height:44px}.text-link{color:#f0d18e;font-size:13px;font-weight:800}
.home-lineup{background:linear-gradient(180deg,transparent,rgba(117,31,54,.08),transparent)}.lineup-head{align-items:center}.home-singer-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:15px}.home-singer-card{text-align:center;padding-bottom:15px;border:1px solid var(--line);border-radius:17px;background:rgba(255,255,255,.04);overflow:hidden}.home-singer-photo{display:grid;place-items:center;aspect-ratio:4/5;background:linear-gradient(145deg,#65304b,#1b1118);overflow:hidden}.home-singer-photo.male{background:linear-gradient(145deg,#234a6b,#101b29)}.home-singer-photo img{width:100%;height:100%;object-fit:cover}.home-singer-photo span{font-size:58px;font-weight:900}.home-singer-card h3{margin:11px 6px 1px}.home-singer-card small{display:block;color:var(--muted);padding:0 8px}
.artist-detail-section{padding:34px 0 62px}.artist-breadcrumb{display:flex;gap:8px;color:var(--muted);font-size:13px;margin-bottom:18px}.artist-profile{display:grid;grid-template-columns:minmax(280px,410px) 1fr;gap:34px;border:1px solid var(--line);border-radius:28px;background:linear-gradient(145deg,rgba(255,255,255,.065),rgba(255,255,255,.025));padding:24px;box-shadow:var(--shadow)}.artist-profile-photo{display:grid;place-items:center;aspect-ratio:4/5;border-radius:21px;overflow:hidden;background:linear-gradient(145deg,#65304b,#1b1118)}.artist-profile-photo.male{background:linear-gradient(145deg,#234a6b,#101b29)}.artist-profile-photo img{width:100%;height:100%;object-fit:cover}.artist-profile-photo>span{font-size:112px;font-weight:900}.artist-profile-content{padding:8px 10px}.profile-title-row{display:flex;justify-content:space-between;gap:18px}.profile-title-row h1{font-size:46px;margin:8px 0 0}.profile-title-row h2{font-size:18px;color:var(--gold);margin:3px 0 20px}.featured-badge{padding:8px 12px;border-radius:999px;border:1px solid rgba(219,181,106,.45);color:#f0d18e;font-size:12px}.artist-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:11px;margin:10px 0 20px}.artist-facts>div{padding:13px;border-radius:13px;background:rgba(255,255,255,.045);border:1px solid var(--line)}.artist-facts small{display:block;color:var(--muted)}.profile-block{padding:16px 0;border-top:1px solid var(--line)}.profile-block h3{margin:0 0 7px;color:#f0d18e}.profile-block p{margin:0;color:var(--muted)}.profile-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}.related-head{display:flex;justify-content:space-between;align-items:center;margin:36px 0 15px}.related-singers{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.related-singer{display:flex;gap:12px;align-items:center;padding:11px;border:1px solid var(--line);border-radius:15px}.related-photo{width:58px;height:70px;display:grid;place-items:center;border-radius:10px;overflow:hidden;background:#65304b}.related-photo.male{background:#234a6b}.related-photo img{width:100%;height:100%;object-fit:cover}.related-singer small{display:block;color:var(--muted)}
@media(max-width:1050px){.singer-grid{grid-template-columns:repeat(3,1fr)}.home-singer-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:820px){.singer-hero-grid,.artist-profile{grid-template-columns:1fr}.singer-grid{grid-template-columns:repeat(2,1fr)}.home-singer-grid{grid-template-columns:repeat(2,1fr)}.singer-filter{flex-direction:column;align-items:stretch}.related-singers{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.singer-grid{grid-template-columns:1fr}.profile-title-row{display:block}.artist-facts,.profile-columns{grid-template-columns:1fr}.related-singers{grid-template-columns:1fr}}


/* 全歌手照片上架與美化排列 */
.home-singer-grid,
.singer-grid{
  display:grid !important;
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  gap:18px !important;
  align-items:stretch;
}

.home-singer-card,
.singer-card{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  border:1px solid rgba(219,181,106,.22);
  background:
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.025));
  box-shadow:0 18px 45px rgba(0,0,0,.18);
  min-width:0;
}

.home-singer-card::after,
.singer-card::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(219,181,106,.75),transparent);
  opacity:.75;
}

.singer-card:hover,
.home-singer-card:hover{
  transform:translateY(-4px);
  border-color:rgba(219,181,106,.55);
  box-shadow:0 22px 55px rgba(0,0,0,.28);
}

.home-singer-photo,
.singer-photo{
  aspect-ratio:4/5 !important;
  width:100%;
  display:grid !important;
  place-items:center;
  overflow:hidden;
  position:relative;
  background:linear-gradient(145deg,#65304b,#1b1118);
}

.home-singer-photo.male,
.singer-photo.male{
  background:linear-gradient(145deg,#234a6b,#101b29);
}

.home-singer-photo img,
.singer-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
  transition:transform .35s ease, filter .35s ease;
}

.home-singer-card:hover img,
.singer-card:hover img{
  transform:scale(1.035);
  filter:saturate(1.06) contrast(1.03);
}

.home-singer-card h3,
.singer-card h3{
  font-size:clamp(17px,1.35vw,22px) !important;
  line-height:1.22;
  margin-top:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.home-singer-card small,
.singer-card strong{
  display:block;
  font-size:clamp(11px,1vw,13px) !important;
  line-height:1.4;
  min-height:1.4em;
}

.singer-card-body{
  padding:15px 15px 17px !important;
}

.singer-card p{
  font-size:clamp(12px,.95vw,13px) !important;
  line-height:1.55;
  margin-top:8px;
  min-height:4.6em;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.singer-card .text-link{
  display:inline-flex;
  margin-top:8px;
}

.singer-photo em{
  backdrop-filter:blur(8px);
}

/* 個人頁照片更精緻 */
.artist-profile{
  align-items:start;
}

.artist-profile-photo{
  box-shadow:inset 0 0 0 1px rgba(219,181,106,.35),0 22px 50px rgba(0,0,0,.25);
}

.artist-profile-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
}

/* 大螢幕固定 5 位一排 */
@media(min-width:1101px){
  .home-singer-grid,
  .singer-grid{
    grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  }
}

/* 筆電與較小桌機：4 位 */
@media(max-width:1100px){
  .home-singer-grid,
  .singer-grid{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  }
}

/* 平板：3 位 */
@media(max-width:900px){
  .home-singer-grid,
  .singer-grid{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
}

/* 手機：2 位 */
@media(max-width:640px){
  .home-singer-grid,
  .singer-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
  }
  .singer-card-body{
    padding:12px !important;
  }
  .singer-card p{
    -webkit-line-clamp:2;
    min-height:3.2em;
  }
}

/* 小手機：保持 2 位，壓縮留白 */
@media(max-width:420px){
  .home-singer-grid,
  .singer-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:10px !important;
  }
  .home-singer-card{
    padding-bottom:10px;
  }
}


/* 歌手人物設定摘要 */
.singer-quick-facts{
  display:grid;
  gap:6px;
  margin:10px 0 12px;
}

.singer-quick-facts span{
  display:block;
  padding:6px 8px;
  border-radius:9px;
  background:rgba(255,255,255,.045);
  color:var(--muted);
  font-size:11px;
  line-height:1.4;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.singer-card{
  display:flex;
  flex-direction:column;
}

.singer-card-body{
  display:flex;
  flex:1;
  flex-direction:column;
}

.singer-card .text-link{
  margin-top:auto;
}

@media(max-width:640px){
  .singer-quick-facts span{
    font-size:10px;
    padding:5px 6px;
  }
}
