:root{
  --gold:#C9A84C;--gold-b:#E8C96B;
  --red:#8B1A1A;
  --ink:#080808;--ink2:#101010;--smoke:#181818;
  --w:rgba(250,248,242,1);
  --w65:rgba(250,248,242,0.65);
  --w40:rgba(250,248,242,0.40);
  --w20:rgba(250,248,242,0.20);
  --w08:rgba(250,248,242,0.08);
  --w04:rgba(250,248,242,0.04);
  --g50:rgba(201,168,76,0.50);
  --g25:rgba(201,168,76,0.25);
  --g10:rgba(201,168,76,0.10);
  --g04:rgba(201,168,76,0.04);
  --content-1280:1280px;
  --content-1440:1440px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--ink);color:var(--w);font-family:'Noto Serif JP',serif;overflow-x:hidden;}
::-webkit-scrollbar{width:2px;}
::-webkit-scrollbar-thumb{background:var(--gold);}

/* ─ UTILITIES ─ */
.div{width:100%;height:1px;background:linear-gradient(to right,transparent,var(--g25),transparent);}
.sec{padding:90px 60px;}
.sec > :is(.sec-label,.sec-title,.sec-en,.ach-grid,.plans-grid,.custom-mask-card,.plans-note,.movie-grid,.video-more,.why-grid,.contact-grid){
  max-width:var(--content-1280);margin-left:auto;margin-right:auto;
}
#achievements > .ach-grid{max-width:var(--content-1440);}
#pricing > :is(.plans-grid,.custom-mask-card,.plans-note){max-width:var(--content-1280);}
.sec-label{font-size:12px;letter-spacing:5px;color:var(--gold);display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.sec-label::before{content:'';width:20px;height:1px;background:var(--gold);}
.sec-title{font-size:clamp(26px,3.5vw,42px);font-weight:700;line-height:1.2;margin-bottom:6px;}
.sec-title span{color:var(--gold);}
.sec-en{font-family:'Cinzel',serif;font-size:11px;letter-spacing:5px;color:var(--w20);margin-bottom:48px;}
.btn-gold{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--gold);color:var(--ink);
  font-family:'Noto Serif JP',serif;font-size:11px;letter-spacing:3px;font-weight:700;
  padding:14px 34px;text-decoration:none;border:none;cursor:pointer;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
  transition:background .3s,transform .2s;
}
.btn-gold:hover{background:var(--gold-b);transform:translateY(-2px);}
.btn-outline{
  display:inline-flex;align-items:center;gap:10px;
  background:none;color:var(--w65);
  font-family:'Noto Serif JP',serif;font-size:11px;letter-spacing:3px;
  padding:13px 28px;text-decoration:none;
  border:1px solid var(--w20);
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
  transition:border-color .3s,color .3s,transform .2s;
}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);}

/* ══ NAV ══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 48px;
  transition:background .4s,backdrop-filter .4s;
}
nav.scrolled{background:rgba(8,8,8,0.97);backdrop-filter:blur(20px);}
.logo{text-decoration:none;display:flex;flex-direction:column;}
.logo-m{font-family:'Cinzel',serif;font-size:20px;letter-spacing:5px;color:var(--gold-b);font-weight:900;}
.logo-s{font-size:12px;letter-spacing:2px;color:rgba(232,201,107,.72);margin-top:2px;font-weight:700;}
.nav-c{display:flex;align-items:center;gap:28px;}
.nav-links{display:flex;gap:24px;list-style:none;}
.nav-links a{color:var(--w40);text-decoration:none;font-size:12px;letter-spacing:2px;transition:color .3s;}
.nav-links a:hover{color:var(--gold);}
.nav-lang-note{font-size:10px;letter-spacing:2px;color:var(--g25);border:1px solid var(--g25);padding:5px 12px;}
.nav-cta-btn{
  background:var(--gold);color:var(--ink);font-family:'Noto Serif JP',serif;
  font-size:12px;letter-spacing:2px;font-weight:700;padding:9px 22px;
  text-decoration:none;
  clip-path:polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,5px 100%,0 calc(100% - 5px));
  transition:background .3s;
}
.nav-cta-btn:hover{background:var(--gold-b);}

/* ══ 1. HERO ══ */
#hero{min-height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden;}
.hero-bg{
  position:absolute;inset:0;overflow:hidden;
  background:
    radial-gradient(ellipse 70% 90% at 75% 50%,#1f0505 0%,#0d0202 40%,#060101 100%),
    #060101;
}
.hero-bg::before{
  content:'';position:absolute;inset:-7% -4% -7% 42%;z-index:0;
  background:url('assets/hero-main.jpg') center center/contain no-repeat;
  opacity:.42;filter:blur(18px) saturate(1.18) contrast(1.08) brightness(.55);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 18%,#000 74%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,#000 18%,#000 74%,transparent 100%);
  pointer-events:none;
}
.hero-main-visual{
  position:absolute;right:max(56px,calc((100vw - var(--content-1440)) / 2 + 56px));top:50%;z-index:1;
  width:min(40vw,620px);height:min(92vh,860px);
  transform:translateY(-50%);
  object-fit:contain;object-position:center center;
  opacity:.98;
  filter:saturate(1.16) contrast(1.13) brightness(1.02) drop-shadow(-24px 24px 46px rgba(0,0,0,.58));
  -webkit-mask-image:radial-gradient(ellipse 82% 76% at 50% 50%,#000 0%,#000 56%,rgba(0,0,0,.78) 68%,transparent 92%);
  mask-image:radial-gradient(ellipse 82% 76% at 50% 50%,#000 0%,#000 56%,rgba(0,0,0,.78) 68%,transparent 92%);
  pointer-events:none;
}
.hero-glow{
  position:absolute;right:10%;top:50%;z-index:0;transform:translateY(-50%);
  width:460px;height:460px;border-radius:50%;
  background:radial-gradient(circle,rgba(139,26,26,0.32) 0%,transparent 70%);
  animation:glow-p 5s ease-in-out infinite;
}
@keyframes glow-p{0%,100%{opacity:.7;transform:translateY(-50%) scale(1);}50%{opacity:1;transform:translateY(-52%) scale(1.06);}}
.hero-ring{
  position:absolute;right:10%;top:50%;z-index:0;transform:translateY(-50%);
  width:370px;height:370px;border-radius:50%;
  border:1px solid rgba(201,168,76,0.09);
  animation:spin-r 24s linear infinite;
}
.hero-ring2{
  position:absolute;right:10%;top:50%;z-index:0;transform:translateY(-50%);
  width:440px;height:440px;border-radius:50%;
  border:1px dashed rgba(201,168,76,0.04);
  animation:spin-r 40s linear infinite reverse;
}
@keyframes spin-r{from{transform:translateY(-50%) rotate(0);}to{transform:translateY(-50%) rotate(360deg);}}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to right,rgba(8,8,8,0.97) 0%,rgba(8,8,8,0.86) 43%,rgba(8,8,8,0.10) 74%,rgba(8,8,8,0.16) 100%),
    linear-gradient(to top,rgba(8,8,8,0.66) 0%,transparent 45%);
}
.hero-video-note{
  position:absolute;right:12%;top:50%;transform:translateY(-50%);
  font-size:10px;letter-spacing:2px;color:rgba(201,168,76,0.18);
  text-align:center;line-height:2.2;z-index:1;pointer-events:none;
}
.hero-inner{
  position:relative;z-index:2;width:min(calc(100% - 120px),var(--content-1440));
  margin:0 auto;padding:0 0 80px;
  max-width:var(--content-1440);animation:fadeUp .9s ease .1s both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);}}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;letter-spacing:3px;color:var(--gold);
  border:1px solid var(--g25);padding:7px 16px;margin-bottom:28px;
}
.hero-badge::before{content:'◆';font-size:4px;}
.hero-performer{font-size:15px;letter-spacing:3px;color:var(--w65);margin-bottom:14px;}
.hero-title{font-size:clamp(58px,6.4vw,92px);font-weight:900;line-height:1.04;margin-bottom:18px;}
.hero-title .gold{color:var(--gold);display:block;}
.hero-sub{
  max-width:700px;font-size:clamp(18px,1.5vw,21px);
  color:rgba(250,248,242,.68);letter-spacing:2px;
  line-height:1.75;font-weight:400;margin-bottom:10px;
}
.hero-meta{font-size:15px;color:rgba(250,248,242,.55);letter-spacing:1px;margin-bottom:42px;font-weight:300;}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:36px;}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;max-width:760px;}
.hb{
  font-size:12px;letter-spacing:1px;color:var(--w65);
  background:var(--w04);border:1px solid var(--w08);
  padding:7px 14px;display:flex;align-items:center;gap:6px;
}
.hb::before{content:'';width:3px;height:3px;border-radius:50%;background:var(--gold);flex-shrink:0;}
.scroll-cue{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  color:var(--w20);font-size:10px;letter-spacing:4px;
  animation:pulse 2.5s ease-in-out infinite;
}
.scroll-cue-line{width:1px;height:28px;background:linear-gradient(to bottom,var(--gold),transparent);}
@keyframes pulse{0%,100%{opacity:.4;}50%{opacity:.9;}}

/* ══ 2. ACHIEVEMENTS ══ */
#achievements{background:var(--ink2);}
.ach-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;align-items:stretch;}
.ach-card{
  min-height:430px;padding:30px 26px;background:var(--smoke);position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  border-left:2px solid transparent;transition:background .3s,border-color .3s;
}
.ach-card:hover{background:#1e1e1e;border-left-color:var(--gold);}
.ach-card-texture{
  background:
    radial-gradient(circle at 82% 18%,rgba(201,168,76,.12),transparent 34%),
    linear-gradient(135deg,#160909,#181818 58%,#0b0b0b);
}
.ach-card.feat{
  grid-column:span 2;
  min-height:430px;
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(220px,.72fr);
  grid-template-rows:auto auto 1fr;
  column-gap:24px;
  align-items:start;
  background:linear-gradient(135deg,#130606,#1e0a0a);
  border-left:2px solid var(--gold);
}
.ach-deco{position:absolute;top:16px;right:16px;font-size:36px;opacity:.05;}
.ach-year{font-family:'Cinzel',serif;font-size:15px;letter-spacing:3px;color:var(--gold);margin-bottom:12px;opacity:.86;}
.ach-chip{display:inline-block;font-size:14px;letter-spacing:1.5px;color:var(--gold);border:1px solid var(--g25);padding:7px 15px;margin-bottom:14px;}
.ach-media{
  aspect-ratio:4/3;height:auto;margin:0 0 18px;overflow:hidden;flex-shrink:0;
  background:#120f0f;border:1px solid var(--w08);border-bottom-color:var(--g25);
}
.ach-card.feat .ach-media{aspect-ratio:16/9;}
.ach-card.feat .ach-media-maotai{
  grid-row:1 / span 5;
  aspect-ratio:1/1;height:auto;min-height:390px;margin:0;
}
.ach-media img{
  display:block;width:100%;height:100%;object-fit:cover;
  filter:saturate(.92) contrast(1.05) brightness(.82);
  transition:transform .45s ease,filter .45s ease;
}
.ach-media-maotai img{
  object-fit:cover;object-position:center 40%;
}
.ach-media-full{aspect-ratio:4/3;}
.ach-media-full img{
  object-fit:cover;object-position:center center;
}
.ach-media-news img{
  object-position:center top;
}
.ach-media-ueno,.ach-media-corporate{aspect-ratio:4/3;}
.ach-media-ueno img{object-position:center center;}
.ach-media-corporate img{object-position:center center;}
.ach-card:hover .ach-media img{transform:scale(1.04);filter:saturate(1) contrast(1.08) brightness(.9);}
.ach-card:hover .ach-media-full img{transform:none;}
.ach-card:hover .ach-media-maotai img{transform:none;}
.ach-card:hover .ach-media-news img{transform:none;}
.ach-card:hover .ach-media-ueno img,.ach-card:hover .ach-media-corporate img{transform:none;}
.ach-name{font-size:24px;font-weight:700;line-height:1.2;margin-bottom:10px;}
.ach-card.feat .ach-name{font-size:30px;}
.ach-card.feat .ach-year{margin-bottom:8px;}
.ach-card.feat .ach-chip{margin-bottom:14px;}
.ach-card.feat .ach-desc{align-self:end;}
.ach-desc{font-size:15px;color:var(--w65);line-height:1.75;font-weight:300;}
.ach-media-card{
  grid-column:1 / -1;min-height:0;padding:26px 28px;
  display:grid;grid-template-columns:minmax(280px,.52fr) 1fr;gap:28px;align-items:center;
  background:linear-gradient(135deg,#121212,#17100d 56%,#0b0b0b);
  border-left-color:var(--g25);
}
.ach-media-card .ach-deco{font-size:42px;}
.ach-media-card .ach-media{grid-row:1 / span 5;margin:0;aspect-ratio:16/9;}
.ach-media-card .ach-name{font-size:25px;margin-bottom:8px;}
.ach-media-card .ach-desc{max-width:620px;}

/* ══ 3. PLANS ══ */
#plans{background:var(--ink);}
.plans-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.plan-card{
  padding:36px 24px;background:var(--smoke);position:relative;overflow:hidden;
  transition:transform .3s,background .3s;
}
.plan-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(to right,transparent,var(--gold),transparent);
  transform:scaleX(0);transition:transform .4s;
}
.plan-card:hover{transform:translateY(-5px);background:#1e1e1e;}
.plan-card:hover::after{transform:scaleX(1);}
.plan-card.feat{
  background:linear-gradient(160deg,#130808,#1e0c0c);
  border-top:2px solid var(--gold);
}
.plan-num{
  font-family:'Cinzel',serif;font-size:48px;font-weight:900;
  color:rgba(201,168,76,0.05);position:absolute;top:10px;right:14px;line-height:1;
}
.plan-icon{font-size:24px;margin-bottom:16px;}
.plan-label{font-size:12px;letter-spacing:3px;color:var(--gold);margin-bottom:7px;}
.plan-name{font-size:22px;font-weight:700;margin-bottom:12px;line-height:1.2;}
.plan-scene-label{font-size:12px;letter-spacing:2px;color:var(--w40);margin-bottom:6px;}
.plan-scene-val{font-size:44px;color:var(--gold-b);opacity:1;margin-bottom:14px;line-height:1.05;font-weight:900;font-family:'Cinzel','Noto Serif JP',serif;}
.plan-body{font-size:15px;color:var(--w65);line-height:1.75;font-weight:300;}
.plan-time{
  display:block;margin-top:14px;font-size:13px;letter-spacing:1px;color:var(--w40);
  border-top:1px solid var(--w08);padding-top:12px;
}
.plans-note{
  margin-top:20px;padding:18px 24px;
  background:var(--w04);border-left:2px solid var(--g25);
  font-size:14px;color:var(--w65);line-height:1.8;font-weight:300;
}
.plans-note strong{color:var(--gold);font-weight:700;}
.custom-mask-card{
  margin-top:22px;padding:24px 28px;
  display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:28px;align-items:center;
  background:linear-gradient(135deg,#121212,#170c0c 58%,#0b0b0b);
  border-left:2px solid var(--g25);
  border-top:1px solid rgba(201,168,76,.08);
}
.custom-mask-title{font-size:24px;line-height:1.25;margin:4px 0 8px;font-weight:700;}
.custom-mask-sub{font-size:14px;color:var(--gold);letter-spacing:1px;line-height:1.7;margin-bottom:10px;}
.custom-mask-price{
  font-family:'Cinzel','Noto Serif JP',serif;font-size:34px;line-height:1.05;
  font-weight:900;color:var(--gold-b);margin-bottom:12px;
}
.custom-mask-copy p{font-size:15px;color:var(--w65);line-height:1.8;font-weight:300;margin-bottom:12px;}
.custom-mask-notes{list-style:none;display:grid;gap:4px;font-size:13px;color:var(--w40);line-height:1.7;font-weight:300;}
.custom-mask-media{
  margin:0;aspect-ratio:1/1;overflow:hidden;background:#0a0a0a;
  border:1px solid var(--g25);padding:10px;
}
.custom-mask-media img{
  width:100%;height:100%;display:block;object-fit:contain;background:#f7f7f7;
}

/* ══ 4. VIDEO ══ */
#video{background:var(--ink2);}
.movie-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2px;}
.movie-card{
  background:var(--smoke);
  border:1px solid rgba(201,168,76,.08);
  overflow:hidden;
}
.movie-frame{
  position:relative;aspect-ratio:16/9;background:#080808;
  overflow:hidden;border-bottom:1px solid rgba(201,168,76,.12);
}
.movie-frame::before{
  content:none;
}
.movie-frame::after{
  content:none;
}
.movie-frame video{
  position:relative;z-index:1;width:100%;height:100%;
  object-fit:contain;display:block;background:#080808;pointer-events:auto;
}
.movie-cap{padding:22px 24px 26px;}
.vplat{font-size:12px;letter-spacing:4px;color:var(--gold);margin-bottom:6px;}
.vtitle{font-size:18px;font-weight:700;}
.movie-desc{font-size:14px;color:var(--w40);line-height:1.8;font-weight:300;margin-top:8px;}
.video-more{margin-top:22px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap;}

/* ══ 5. WHY ══ */
#why{background:var(--ink);}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;}
.why-card{
  padding:40px 36px;background:var(--smoke);
  display:flex;gap:28px;align-items:flex-start;
  border-bottom:2px solid transparent;
  transition:border-color .3s,background .3s;
}
.why-card:hover{border-bottom-color:var(--gold);background:#1e1e1e;}
.why-icon-wrap{
  width:52px;height:52px;flex-shrink:0;
  background:var(--g10);border:1px solid var(--g25);
  display:flex;align-items:center;justify-content:center;font-size:22px;
  clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,6px 100%,0 calc(100% - 6px));
}
.why-title{font-size:19px;font-weight:700;margin-bottom:10px;}
.why-text{font-size:15px;color:var(--w65);line-height:1.85;font-weight:300;}
.why-detail{font-size:11px;color:var(--gold);letter-spacing:1px;margin-top:10px;opacity:.75;line-height:1.8;}

/* ══ 6. PROFILE ══ */
#profile{
  background:var(--ink2);display:grid;
  grid-template-columns:380px minmax(0,700px);
  gap:84px;align-items:center;justify-content:center;
  padding-left:max(60px,calc((100vw - var(--content-1280)) / 2));
  padding-right:max(60px,calc((100vw - var(--content-1280)) / 2));
}
.pf-left{position:relative;display:inline-flex;}
.portrait{
  width:360px;height:460px;
  background:linear-gradient(135deg,#160707,#220d0d);
  border:1px solid var(--g25);
  clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,18px 100%,0 calc(100% - 18px));
  display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
}
.portrait img{
  position:relative;z-index:1;width:100%;height:100%;display:block;
  object-fit:cover;object-position:center 30%;
  filter:saturate(1.03) contrast(1.04) brightness(.96);
}
.portrait::before{display:none;}
.portrait::after{
  content:'';position:absolute;inset:12px;z-index:2;border:1px solid var(--g10);
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
  pointer-events:none;
}
.pf-vert-name{
  writing-mode:vertical-rl;font-size:12px;letter-spacing:4px;
  color:var(--gold);opacity:.45;margin-left:-20px;margin-top:20px;align-self:flex-start;
}
.pf-vert-org{
  writing-mode:vertical-rl;font-size:10px;letter-spacing:3px;
  color:var(--w20);position:absolute;right:-16px;top:0;bottom:0;
  display:flex;align-items:center;
}
.pf-right .sec-title{margin-bottom:4px;}
.pf-sub{font-size:14px;color:var(--g50);letter-spacing:2px;margin-bottom:24px;}
.pf-right{max-width:700px;}
.pf-right p{font-size:16px;color:var(--w65);line-height:1.9;margin-bottom:14px;font-weight:300;}
.pf-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px;}
.ptag{font-size:12px;letter-spacing:2px;padding:6px 13px;border:1px solid var(--g25);color:var(--g50);background:var(--g04);}

/* ══ 7. CONTACT ══ */
#contact{background:var(--smoke);}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;margin-top:48px;}
.cl h3{font-size:17px;color:var(--gold);letter-spacing:2px;margin-bottom:14px;}
.cl p{font-size:15px;color:var(--w65);line-height:1.85;margin-bottom:28px;font-weight:300;}
.channels{display:flex;flex-direction:column;}
.ch{
  display:flex;align-items:center;gap:14px;padding:13px 0;
  border-bottom:1px solid rgba(250,248,242,.05);
  text-decoration:none;color:var(--w65);font-size:12px;letter-spacing:1px;transition:color .3s;
}
.ch:hover{color:var(--gold);}
.ch-ico{
  width:32px;height:32px;flex-shrink:0;
  border:1px solid var(--g25);font-size:13px;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .3s,background .3s;
}
.ch:hover .ch-ico{border-color:var(--gold);background:var(--g10);}
.ch-name{font-size:16px;letter-spacing:1px;}
.ch-note{font-size:14px;letter-spacing:1px;color:var(--w40);margin-top:2px;display:block;}
.cform{display:flex;flex-direction:column;gap:13px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg label{font-size:12px;letter-spacing:3px;color:var(--g50);}
.fg input,.fg select,.fg textarea{
  background:var(--w04);border:1px solid rgba(250,248,242,.08);
  border-bottom:1px solid var(--g25);color:var(--w);
  font-family:'Noto Serif JP',serif;font-size:15px;padding:12px 14px;
  outline:none;transition:border-color .3s,background .3s;border-radius:0;-webkit-appearance:none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-bottom-color:var(--gold);background:var(--g04);}
.fg select option{background:#1c1c1c;}
.fg textarea{min-height:88px;resize:vertical;}
.fnote{font-size:12px;letter-spacing:1px;color:var(--w40);}

/* ══ FOOTER ══ */
footer{
  background:#050505;padding:32px 60px;
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid rgba(201,168,76,.07);
}
.fl{font-family:'Cinzel',serif;font-size:11px;letter-spacing:5px;color:rgba(201,168,76,.3);}
.fc{font-size:12px;color:var(--w40);letter-spacing:2px;line-height:1.8;}
.fo{font-size:12px;letter-spacing:2px;color:rgba(201,168,76,.35);}

/* ══ FLOAT ══ */
.float{position:fixed;bottom:24px;right:max(18px,calc((100vw - var(--content-1440)) / 2 + 18px));z-index:180;display:flex;flex-direction:column;gap:8px;align-items:flex-end;}
.fb{
  display:flex;align-items:center;gap:9px;padding:9px 17px;
  font-family:'Noto Serif JP',serif;font-size:10px;letter-spacing:2px;
  text-decoration:none;border:none;cursor:pointer;
  clip-path:polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,5px 100%,0 calc(100% - 5px));
  transition:transform .25s;
}
.fb:hover{transform:translateX(-3px);}
.fb-main{background:var(--gold);color:var(--ink);font-weight:700;font-size:11px;padding:12px 22px;box-shadow:0 8px 28px rgba(201,168,76,.3);}
.fb-line{background:rgba(0,185,0,0.9);color:#fff;}
.fb-ig{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff;}
.fb-icon{font-size:13px;}
@media(max-width:768px){.fb-ig{display:none;}}

/* ══ RESPONSIVE ══ */
@media(max-width:768px){
  nav{padding:15px 18px;}
  .logo-m{font-size:18px;}
  .logo-s{font-size:11px;color:rgba(232,201,107,.72);}
  .nav-links,.nav-cta-btn{display:none;}
  .sec{padding:60px 18px;}
  #hero{min-height:100svh;}
  .hero-inner{width:auto;max-width:none;margin:0;padding:0 18px 68px;}
  .hero-main-visual{
    left:0;right:auto;top:0;width:100%;height:100%;
    transform:none;object-fit:cover;object-position:center 26%;
    opacity:.64;
    filter:saturate(1.08) contrast(1.1) brightness(.78);
    -webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.92) 0%,#000 38%,rgba(0,0,0,.76) 68%,transparent 100%);
    mask-image:linear-gradient(to bottom,rgba(0,0,0,.92) 0%,#000 38%,rgba(0,0,0,.76) 68%,transparent 100%);
  }
  .hero-bg::before{
    inset:0;opacity:.28;filter:blur(16px) saturate(1.12) brightness(.45);
    background-size:cover;background-position:center 24%;
    -webkit-mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.7) 58%,transparent 100%);
    mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,.7) 58%,transparent 100%);
  }
  .hero-overlay{
    background:
      linear-gradient(to bottom,rgba(8,8,8,.42) 0%,rgba(8,8,8,.72) 48%,rgba(8,8,8,.96) 100%),
      linear-gradient(to right,rgba(8,8,8,.88),rgba(8,8,8,.42));
  }
  .hero-ring,.hero-ring2,.hero-glow{width:220px;height:220px;right:5%;}
  .hero-badge{font-size:10px;padding:6px 13px;}
  .hero-performer{font-size:12px;}
  .hero-title{font-size:clamp(42px,13vw,58px);}
  .hero-meta{font-size:12px;}
  .hero-sub{font-size:15px;line-height:1.7;}
  .hero-badges{max-width:none;}
  .hb{font-size:11px;padding:6px 12px;}
  .ach-grid{grid-template-columns:1fr;}
  .ach-card.feat{grid-column:span 1;display:flex;}
  .ach-card{min-height:0;}
  .ach-year{font-size:13px;}
  .ach-chip{font-size:12px;line-height:1.5;}
  .ach-name{font-size:22px;}
  .ach-card.feat .ach-name{font-size:25px;}
  .ach-desc{font-size:14px;line-height:1.75;}
  .ach-card.feat .ach-media-maotai{aspect-ratio:1/1;min-height:0;height:auto;margin:0 0 18px;}
  .ach-media-card{grid-column:span 1;display:flex;gap:0;padding:30px 26px;}
  .ach-media-card .ach-media{grid-row:auto;margin:0 0 18px;aspect-ratio:4/3;width:100%;}
  .plans-grid{grid-template-columns:1fr;}
  .plan-name{font-size:20px;}
  .plan-scene-val{font-size:34px;line-height:1.05;}
  .plan-body{font-size:14px;line-height:1.8;}
  .plan-time,.plans-note{font-size:13px;}
  .custom-mask-card{grid-template-columns:1fr;padding:22px 20px;gap:18px;}
  .custom-mask-media{width:min(100%,260px);justify-self:center;}
  .custom-mask-title{font-size:22px;}
  .custom-mask-price{font-size:32px;}
  .custom-mask-copy p{font-size:14px;}
  .custom-mask-notes{font-size:13px;}
  .movie-grid{grid-template-columns:1fr;}
  .movie-cap{padding:18px 18px 22px;}
  .why-grid{grid-template-columns:1fr;}
  #profile{grid-template-columns:1fr;padding:60px 18px;gap:40px;justify-content:stretch;}
  .portrait{width:220px;height:290px;}
  .contact-grid{grid-template-columns:1fr;}
  .frow{grid-template-columns:1fr;}
  footer{flex-direction:column;gap:8px;text-align:center;padding:24px 18px;}
  .float{bottom:16px;right:14px;}
  .fb{padding:9px 16px;font-size:9px;}
  .fb-main{padding:11px 20px;font-size:10px;}
}
